/* =========================================================================
   Modern TransCopy — Industrial / Technical redesign
   Mono-forward · grotesk display · visible grid · corner brackets · HUD cyan
   ========================================================================= */

:root {
  /* cool concrete palette */
  --paper:     #E8E9E5;
  --surface:   #F1F2EE;
  --surface-2: #DCDDD7;
  --ink:       #15181C;
  --ink-soft:  #585E66;
  --line:      #C6C8C0;
  --rule:      rgba(21,24,28,.22);

  /* technical accent */
  --electric:  #16C7E6;
  --dtf-electric: var(--electric);
  --dtf-glow:  rgba(22,199,230,.35);
  --navy:      #12294E;
  --navy-bright: #1F4E8C;
  --accent:    var(--electric);
  --success:   #07A86B;
  --gold:      #B58A2E;
  --impact-bg:  #0B0E12;
  --impact-bg-2:#11151B;
  --impact-ink: #EDEFF2;
  --impact-soft:#7E8893;

  --radius:    2px;
  --maxw:      1320px;
  --gut:       clamp(18px, 4.5vw, 56px);
  --nav-h:     70px;

  --sans: "Helvetica Neue", Helvetica, "Inter", "Segoe UI", Roboto, Arial, sans-serif;
  --mono: "SFMono-Regular", ui-monospace, "SF Mono", Menlo, Consolas, "Roboto Mono", monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0; font-family: var(--sans); color: var(--ink); background: var(--paper);
  line-height: 1.55; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

h1, h2, h3, h4 { font-family: var(--sans); font-weight: 700; line-height: 1.02; letter-spacing: -.015em; margin: 0 0 .4em; }
h1 { font-size: clamp(2.4rem, 6.5vw, 5rem); }
h2 { font-size: clamp(1.7rem, 4vw, 3rem); }
h3 { font-size: clamp(1.05rem, 1.7vw, 1.3rem); font-weight: 600; letter-spacing: -.005em; }
p  { margin: 0 0 1em; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gut); }
.section { padding: clamp(48px, 8vw, 120px) 0; }
.lead { font-size: clamp(1.02rem, 1.5vw, 1.22rem); line-height: 1.55; color: var(--ink-soft); max-width: 58ch; font-weight: 400; }

/* technical micro-label */
.eyebrow {
  font-family: var(--mono); font-size: .72rem; font-weight: 500; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ink); margin: 0 0 1.1em; display: inline-flex; align-items: center; gap: .7em;
}
.eyebrow::before { content: ""; width: 7px; height: 7px; background: var(--electric); display: inline-block; }
.center { text-align: center; }
.center .lead { margin-left: auto; margin-right: auto; }
.center .eyebrow { justify-content: center; }

/* numbered technical section header */
.section-head {
  display: grid; grid-template-columns: 4.5rem 1fr; gap: clamp(16px,3vw,40px);
  align-items: start; padding-top: 22px; border-top: 1px solid var(--rule); margin-bottom: clamp(34px,5vw,58px);
}
.section-head .ix { font-family: var(--mono); font-size: .8rem; color: var(--ink-soft); letter-spacing: .04em; padding-top: .5em; }
.section-head .ix::before { content: "[ "; }
.section-head .ix::after { content: " ]"; }
.section-head .eyebrow { margin-bottom: .85em; }
.section-head h2 { max-width: 22ch; margin: 0; text-transform: uppercase; letter-spacing: -.01em; }
.section-head .sh-lead { margin: 14px 0 0; max-width: 48ch; }

/* =========================================================================
   Buttons — rectangular, mono, invert on hover
   ========================================================================= */
.btn {
  display: inline-flex; align-items: center; gap: .6em; font-family: var(--mono);
  font-weight: 500; font-size: .8rem; letter-spacing: .06em; text-transform: uppercase;
  padding: 1em 1.5em; border-radius: var(--radius); border: 1px solid transparent;
  cursor: pointer; transition: background .22s, color .22s, border-color .22s; white-space: nowrap;
}
.btn svg { transition: transform .22s; }
.btn:hover svg { transform: translateX(3px); }
.btn-primary { background: var(--ink); color: var(--paper); }
.btn-primary:hover { background: var(--navy); }
.btn-ghost { background: transparent; border-color: var(--ink); color: var(--ink); }
.btn-ghost:hover { background: var(--ink); color: var(--paper); }
.btn-electric { background: var(--electric); color: #03222b; }
.btn-electric:hover { background: #4fe3ff; }
.btn-outline-light { border-color: rgba(255,255,255,.45); color: #fff; }
.btn-outline-light:hover { background: var(--electric); border-color: var(--electric); color: #03222b; }

.link-arrow { display: inline-flex; align-items: center; gap: .55em; font-family: var(--mono); font-weight: 500; font-size: .78rem; letter-spacing: .06em; text-transform: uppercase; border-bottom: 1px solid currentColor; padding-bottom: 3px; }
.link-arrow svg { transition: transform .22s; }
.link-arrow:hover svg { transform: translateX(4px); }

/* technical corner brackets utility */
.brk { position: relative; }
.brk::before, .brk::after { content: ""; position: absolute; width: 9px; height: 9px; border: 1px solid var(--ink); pointer-events: none; z-index: 3; }
.brk::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.brk::after { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }

/* =========================================================================
   NAV
   ========================================================================= */
header.nav {
  position: sticky; top: 0; z-index: 100; background: rgba(232,233,229,.82);
  backdrop-filter: saturate(140%) blur(14px); -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--rule);
}
.nav-inner { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gut); height: var(--nav-h); display: flex; align-items: center; gap: 20px; }
.nav-logo { display: flex; align-items: center; gap: 10px; }
.nav-logo img { height: 28px; width: auto; }
.nav-menu { display: flex; align-items: center; gap: 0; margin-left: 28px; }
.nav-item { position: relative; }
.nav-link {
  display: inline-flex; align-items: center; gap: 7px; padding: 10px 15px; font-family: var(--mono);
  font-weight: 500; font-size: .82rem; letter-spacing: .04em; text-transform: uppercase; cursor: pointer; color: var(--ink); transition: color .18s;
}
.nav-link:hover { color: var(--electric); }
.nav-link .caret { display: inline-flex; align-items: center; color: var(--ink-soft); transition: transform .25s ease, color .2s; }
.nav-link .caret svg { display: block; }
.nav-item:hover .nav-link .caret { transform: rotate(180deg); color: var(--electric); }
.nav-spacer { flex: 1; }
.nav-right { display: flex; align-items: center; gap: 14px; }

.dtf-dot::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--electric); box-shadow: 0 0 8px var(--dtf-glow); display: inline-block; margin-right: 3px; }
.coming-soon { font-family: var(--mono); font-size: .56rem; letter-spacing: .08em; text-transform: uppercase; color: var(--electric); margin-left: 5px; }

.lang-switch { display: inline-flex; gap: 4px; font-family: var(--mono); font-size: .76rem; }
.lang-switch button { border: 0; background: transparent; padding: 6px 6px; cursor: pointer; color: var(--ink-soft); font: inherit; }
.lang-switch button.active { color: var(--electric); }

/* mega menu */
.mega {
  position: absolute; top: 100%; left: 0; margin-top: 1px; transform: translateY(6px);
  width: min(1040px, 92vw); max-width: calc(100vw - 32px);
  background: var(--surface); border: 1px solid var(--ink); border-radius: var(--radius); padding: 0;
  max-height: calc(100vh - var(--nav-h) - 20px); overflow-y: auto; overflow-x: hidden;
  opacity: 0; visibility: hidden; transition: opacity .2s, transform .2s; z-index: 120;
}
.nav-item.has-mega:hover .mega, .mega:hover { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-item.has-mega:hover::after { content: ""; position: absolute; left: 0; right: 0; top: 100%; height: 18px; z-index: 119; }
.mega-grid { display: grid; grid-template-columns: 1fr 1fr 1fr 250px; gap: 1px; background: var(--rule); }
.mega-grid > * { background: var(--surface); padding: 24px; }
.mega-divider { height: 1px; background: var(--rule); margin: 16px -14px; }
.mega-list { display: grid; gap: 2px; padding: 16px; }
.mega-col + .mega-col { margin-top: 24px; }
.mega-col h4 { font-family: var(--mono); font-size: .66rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 10px; }
/* unified technical mega-link hover (Products + Company): slide + cyan marker */
.mega-link { position: relative; display: block; padding: 11px 14px; transition: transform .22s cubic-bezier(.2,.7,.2,1), color .18s; }
.mega-col .mega-link { margin: 0 -14px; }
.mega-link::before { content: ""; position: absolute; left: 0; top: 9px; bottom: 9px; width: 2px; background: var(--electric); transform: scaleY(0); transform-origin: center; transition: transform .22s cubic-bezier(.2,.7,.2,1); }
.mega-link:hover { transform: translateX(6px); }
.mega-link:hover::before { transform: scaleY(1); }
.mega-link strong { display: block; font-weight: 600; font-size: .95rem; transition: color .18s; }
.mega-link:hover strong { color: var(--electric); }
.mega-link strong::after { content: " →"; opacity: 0; margin-left: 2px; transition: opacity .18s; }
.mega-link:hover strong::after { opacity: 1; }
.mega-link span { font-size: .78rem; color: var(--ink-soft); }
.mega-dtf { background: var(--impact-bg); color: var(--impact-ink); display: flex; flex-direction: column; gap: 12px; justify-content: center; }
.mega-dtf h4 { color: var(--electric); font-family: var(--mono); letter-spacing: .12em; }
.mega-dtf p { font-size: .8rem; color: var(--impact-soft); margin: 0; }

/* =========================================================================
   Mobile nav
   ========================================================================= */
.hamburger { display: none; background: transparent; border: 0; cursor: pointer; padding: 8px; }
.hamburger span { display: block; width: 24px; height: 1.5px; background: var(--ink); margin: 6px 0; transition: .25s; }
.drawer { position: fixed; inset: 0; z-index: 200; background: var(--paper); transform: translateX(100%); transition: transform .3s cubic-bezier(.2,.7,.2,1); display: flex; flex-direction: column; padding: 18px var(--gut) calc(32px + env(safe-area-inset-bottom)); overflow-y: auto; }
.drawer.open { transform: translateX(0); }
.drawer-head { display: flex; align-items: center; justify-content: space-between; height: 54px; margin-bottom: 16px; }
.drawer-close { background: transparent; border: 0; font-size: 1.9rem; cursor: pointer; line-height: 1; }
.drawer-link { display: flex; align-items: center; justify-content: space-between; padding: 17px 2px; font-size: 1.2rem; font-weight: 700; text-transform: uppercase; letter-spacing: -.01em; border-bottom: 1px solid var(--rule); }
.drawer-link .dtf-dot { display: inline-flex; align-items: center; }
.drawer-link .coming-soon { margin-left: 8px; }
.drawer-sub { padding: 8px 0 8px 14px; }
.drawer-sub .mega-divider { height: 1px; background: var(--rule); margin: 10px 0; }
.drawer-sub a { display: block; padding: 9px 2px; font-family: var(--mono); font-size: .82rem; color: var(--ink-soft); }

/* =========================================================================
   HERO — technical
   ========================================================================= */
.hero-impact { position: relative; background: var(--impact-bg); color: var(--impact-ink); overflow: hidden; padding: clamp(72px,14vw,180px) 0 clamp(56px,9vw,120px); }
.hero-impact::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.045) 1px, transparent 1px),
    radial-gradient(1100px 460px at 78% -10%, rgba(22,199,230,.14), transparent 60%);
  background-size: 64px 64px, 64px 64px, 100% 100%;
}
.hero-impact .wrap { position: relative; z-index: 2; }
.hero-impact .eyebrow { color: var(--electric); }
.hero-impact .eyebrow::before { background: var(--electric); }
.hero-meta { display: flex; flex-wrap: wrap; gap: 8px 26px; font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; color: var(--impact-soft); text-transform: uppercase; margin-bottom: 30px; }
.hero-meta span { display: inline-flex; align-items: center; gap: 8px; }
.hero-meta b { color: var(--electric); font-weight: 500; }
.spectral-line { display: none; }
.dtf-word { font-family: var(--sans); font-weight: 800; letter-spacing: -.04em; font-size: clamp(4.5rem, 24vw, 17rem); line-height: .82; margin: 0 0 .1em; color: #fff; }
.hero-impact .sub { color: var(--impact-soft); font-size: clamp(1.02rem,1.6vw,1.3rem); max-width: 48ch; margin: 18px 0 32px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }

/* =========================================================================
   Trust strip
   ========================================================================= */
.trust { background: var(--ink); color: var(--paper); }
.trust .wrap { display: flex; flex-wrap: wrap; gap: 12px 44px; align-items: center; padding: 18px var(--gut); }
.trust .item { display: flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: .76rem; letter-spacing: .05em; text-transform: uppercase; opacity: .92; }
.trust .item svg { color: var(--electric); }

/* =========================================================================
   Thesis
   ========================================================================= */
.thesis-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.thesis-card { background: var(--paper); padding: clamp(28px,4.2vw,52px); display: flex; flex-direction: column; align-items: flex-start; }
.thesis-tag { font-family: var(--mono); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 18px; color: var(--ink-soft); }
.thesis-card h2 { font-size: clamp(1.5rem,2.6vw,2.1rem); text-transform: uppercase; letter-spacing: -.01em; }
.thesis-card p { color: var(--ink-soft); margin-bottom: 24px; }
.thesis-card .btn, .thesis-card .link-arrow { margin-top: auto; }
.thesis-card.impact { background: var(--impact-bg); color: var(--impact-ink); position: relative; overflow: hidden; }
.thesis-card.impact::before { content: ""; position: absolute; inset: 0; background: linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 48px 48px; }
.thesis-card.impact > * { position: relative; z-index: 1; }
.thesis-card.impact .thesis-tag { color: var(--electric); }
.thesis-card.impact h2 { color: #fff; }
.thesis-card.impact p { color: var(--impact-soft); }

/* =========================================================================
   DTF spotlight
   ========================================================================= */
.spotlight { background: var(--impact-bg-2); color: var(--impact-ink); }
.spotlight .grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,6vw,76px); align-items: center; }
.spotlight .eyebrow { color: var(--electric); }
.spotlight .eyebrow::before { background: var(--electric); }
.spotlight p { color: var(--impact-soft); }
.ba { position: relative; overflow: hidden; aspect-ratio: 4/3; border: 1px solid rgba(22,199,230,.25); background: #000; }
.ba img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ba .after { clip-path: inset(0 0 0 var(--split, 50%)); }
.ba .handle { position: absolute; top: 0; bottom: 0; left: var(--split, 50%); width: 1.5px; background: var(--electric); box-shadow: 0 0 14px var(--dtf-glow); }
.ba .handle::after { content: "‹ ›"; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); background: var(--electric); color: #03222b; font-weight: 700; padding: 4px 8px; font-size: .8rem; }
.ba input { position: absolute; inset: 0; opacity: 0; cursor: ew-resize; width: 100%; }
.ba .tag { position: absolute; top: 12px; padding: 4px 9px; font-family: var(--mono); font-size: .64rem; letter-spacing: .06em; text-transform: uppercase; }
.ba .tag.l { left: 12px; background: rgba(0,0,0,.65); color: #fff; }
.ba .tag.r { right: 12px; background: var(--electric); color: #03222b; }

/* =========================================================================
   Steps
   ========================================================================= */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--rule); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); counter-reset: s; }
.step { background: var(--paper); padding: clamp(26px,3.2vw,40px) clamp(20px,2.4vw,30px); counter-increment: s; }
.step .n { font-family: var(--mono); font-size: .8rem; color: var(--electric); margin-bottom: 28px; display: block; }
.step .n::before { content: "[ " counter(s, decimal-leading-zero) " ]"; }
.step h3 { margin-bottom: 10px; text-transform: uppercase; letter-spacing: 0; }
.step p { color: var(--ink-soft); margin: 0; }

/* =========================================================================
   Collection
   ========================================================================= */
.collection { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.cat-card { position: relative; min-height: 320px; display: flex; align-items: flex-end; color: #fff; background: var(--impact-bg); overflow: hidden; }
.cat-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .48; transition: transform .6s cubic-bezier(.2,.7,.2,1), opacity .3s; filter: grayscale(.15); }
.cat-card:hover img { transform: scale(1.05); opacity: .6; }
.cat-card .body { position: relative; z-index: 2; padding: 24px; width: 100%; }
.cat-card h3 { color: #fff; margin-bottom: 5px; font-size: 1.4rem; text-transform: uppercase; }
.cat-card p { margin: 0; font-family: var(--mono); font-size: .78rem; opacity: .82; }
.cat-card.dtf::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent, rgba(22,199,230,.16)); }

/* =========================================================================
   Craft
   ========================================================================= */
.craft { background: var(--impact-bg); color: var(--impact-ink); }
.craft .grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,6vw,76px); align-items: center; }
.craft img { filter: grayscale(.4) contrast(1.05); border: 1px solid rgba(255,255,255,.08); }
.craft p { color: var(--impact-soft); }
.craft .eyebrow { color: var(--electric); }
.craft .eyebrow::before { background: var(--electric); }

/* =========================================================================
   Stats
   ========================================================================= */
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--rule); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.stat { background: var(--paper); padding: clamp(28px,3.6vw,48px) 24px; }
.stat .num { font-family: var(--sans); font-weight: 800; font-size: clamp(2.8rem,6.5vw,4.6rem); color: var(--ink); line-height: 1; font-variant-numeric: tabular-nums; letter-spacing: -.03em; }
.stat .lbl { color: var(--ink-soft); font-family: var(--mono); font-size: .76rem; letter-spacing: .04em; text-transform: uppercase; margin-top: 14px; }

/* =========================================================================
   Cards
   ========================================================================= */
.cards-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.card { background: var(--surface); padding: 30px; }
.card h3 { text-transform: uppercase; font-size: 1.1rem; }
.eco { background: var(--surface-2); }

/* =========================================================================
   CTA band
   ========================================================================= */
.cta-band { background: var(--ink); color: var(--paper); }
.cta-band h2 { color: #fff; text-transform: uppercase; }
.cta-band .lead { color: rgba(255,255,255,.7); }
.cta-band .actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 22px; }

/* =========================================================================
   FAQ
   ========================================================================= */
.faq-list { max-width: 900px; }
.faq-item { border-top: 1px solid var(--rule); }
.faq-item:last-child { border-bottom: 1px solid var(--rule); }
.faq-q { width: 100%; text-align: left; background: transparent; border: 0; padding: 24px 4px; font-size: clamp(1.02rem,1.5vw,1.25rem); font-weight: 600; cursor: pointer; display: flex; justify-content: space-between; gap: 16px; letter-spacing: -.005em; }
.faq-q .ic { font-family: var(--mono); font-weight: 400; font-size: 1.4rem; transition: transform .25s; color: var(--electric); line-height: 1; }
.faq-item.open .faq-q .ic { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.faq-item.open .faq-a { max-height: 460px; }
.faq-a p { padding: 0 4px 26px; color: var(--ink-soft); max-width: 72ch; }

/* =========================================================================
   Footer
   ========================================================================= */
footer.site { background: var(--impact-bg); color: var(--impact-soft); padding: clamp(52px,8vw,90px) 0 32px; border-top: 1px solid rgba(255,255,255,.08); }
footer.site a { color: var(--impact-soft); }
footer.site a:hover { color: var(--electric); }
.foot-grid { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: 36px; }
.foot-grid h5 { color: #fff; font-family: var(--mono); font-size: .66rem; letter-spacing: .14em; text-transform: uppercase; margin: 0 0 16px; }
.foot-grid a { display: block; padding: 6px 0; font-size: .9rem; }
.foot-wordmark { font-family: var(--sans); font-weight: 800; font-size: 1.5rem; letter-spacing: -.01em; text-transform: uppercase; color: #fff; margin: 0 0 14px; }
.foot-contact { font-style: normal; display: flex; flex-direction: column; gap: 4px; margin-top: 14px; font-family: var(--mono); font-size: .84rem; line-height: 1.5; color: #fff; }
.foot-contact a { color: #fff; }
.foot-contact a:hover { color: var(--electric); }
.foot-bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: 46px; padding-top: 22px; display: flex; flex-wrap: wrap; gap: 12px; justify-content: space-between; font-family: var(--mono); font-size: .74rem; }

/* =========================================================================
   Page head / breadcrumb
   ========================================================================= */
.page-head { border-bottom: 1px solid var(--rule); padding: clamp(36px,5vw,72px) 0 clamp(26px,4vw,42px); }
.breadcrumb { font-family: var(--mono); font-size: .76rem; color: var(--ink-soft); margin-bottom: 22px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.breadcrumb a:hover { color: var(--electric); }
.breadcrumb .bc-sep { color: var(--line); }
.breadcrumb .bc-current { color: var(--ink); }
.page-head h1 { margin: 0; text-transform: uppercase; }
.page-head .lead { margin-top: 18px; }

.pdp-section { padding-top: clamp(20px,3vw,32px); }
.pdp-section .breadcrumb { margin-bottom: clamp(24px,4vw,40px); }

/* =========================================================================
   Catalogue
   ========================================================================= */
.product-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px,2.2vw,28px); }
.p-card { display: flex; flex-direction: column; }
.p-card .ph { position: relative; aspect-ratio: 4/5; background: var(--surface-2); overflow: hidden; border: 1px solid var(--ink); }
.p-card .ph::before, .p-card .ph::after { content: ""; position: absolute; width: 10px; height: 10px; border: 1px solid var(--electric); z-index: 2; opacity: 0; transition: opacity .2s; }
.p-card .ph::before { top: 6px; left: 6px; border-right: 0; border-bottom: 0; }
.p-card .ph::after { bottom: 6px; right: 6px; border-left: 0; border-top: 0; }
.p-card:hover .ph::before, .p-card:hover .ph::after { opacity: 1; }
.p-card .ph img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s cubic-bezier(.2,.7,.2,1); }
.p-card:hover .ph img { transform: scale(1.04); }
.p-card .body { padding: 16px 2px 0; flex: 1; display: flex; flex-direction: column; }
.p-card .body h3 { margin-bottom: 6px; font-size: 1.2rem; text-transform: uppercase; letter-spacing: -.01em; }
.p-card .tagline { font-size: .88rem; color: var(--ink-soft); flex: 1; margin: 0 0 16px; }
.p-card .meta { display: flex; align-items: center; justify-content: space-between; padding-top: 12px; border-top: 1px solid var(--rule); }
.price-tag { color: var(--ink); }
.badge { font-family: var(--mono); font-size: .68rem; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-soft); }
.badge.dtf { color: var(--electric); }

.cat-pills { display: flex; flex-wrap: wrap; gap: 6px 24px; margin-top: 8px; }
.cat-pills a { font-family: var(--mono); font-size: .8rem; letter-spacing: .03em; text-transform: uppercase; color: var(--ink-soft); padding: 4px 0; border-bottom: 1.5px solid transparent; }
.cat-pills a:hover { color: var(--ink); }
.cat-pills a.active { color: var(--electric); border-color: var(--electric); }

/* =========================================================================
   PDP
   ========================================================================= */
.pdp { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(30px,5vw,68px); align-items: start; }
.pdp-gallery { position: sticky; top: calc(var(--nav-h) + 22px); }
.pdp-gallery .main { position: relative; aspect-ratio: 4/5; overflow: hidden; background: var(--surface-2); border: 1px solid var(--ink); }
.pdp-gallery .main img { width: 100%; height: 100%; object-fit: cover; }
.pdp-cat-tags { position: absolute; top: 14px; left: 14px; z-index: 2; display: flex; flex-wrap: wrap; gap: 6px; }
.pdp-cat-tag { background: var(--ink); color: var(--paper); font-family: var(--mono); font-size: .66rem; letter-spacing: .05em; text-transform: uppercase; padding: 7px 11px; }
.pdp-cat-tag:hover { background: var(--electric); color: #03222b; }
.pdp-mini-trust { display: flex; flex-wrap: wrap; gap: 8px 22px; margin-top: 16px; }
.pdp-mini-trust span { display: inline-flex; align-items: center; gap: 7px; font-family: var(--mono); font-size: .74rem; color: var(--ink-soft); }
.pdp-mini-trust svg { color: var(--success); }

.pdp-eyebrow { display: inline-block; font-family: var(--mono); font-size: .74rem; letter-spacing: .05em; text-transform: uppercase; color: var(--electric); margin-bottom: 14px; }
.pdp-info h1 { margin: 0 0 .2em; font-size: clamp(2rem,3.6vw,3.2rem); text-transform: uppercase; }
.pdp-type { color: var(--ink-soft); font-family: var(--mono); font-size: .9rem; margin: 0 0 18px; }
.pdp-tagline { font-size: clamp(1.05rem,1.5vw,1.24rem); line-height: 1.5; margin: 0 0 26px; }

.pdp-facts { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--rule); border: 1px solid var(--ink); margin-bottom: 26px; }
.pdp-facts .fact { background: var(--paper); padding: 15px 18px; }
.fact-label { display: block; font-family: var(--mono); font-size: .66rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 6px; }
.fact-value { font-weight: 500; font-size: .96rem; }

.pdp-quote-card { background: var(--surface); border: 1px solid var(--ink); }
.pqc-top { padding: 22px; border-bottom: 1px solid var(--line); }
.pqc-label { display: block; font-family: var(--mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 10px; }
.pqc-price-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.pqc-price { font-family: var(--sans); font-weight: 800; font-size: 1.55rem; color: var(--ink); line-height: 1; letter-spacing: -.02em; text-transform: uppercase; }
.pqc-badge { font-family: var(--mono); font-size: .62rem; letter-spacing: .06em; text-transform: uppercase; padding: 4px 8px; background: var(--ink); color: var(--paper); }
.pqc-note { display: flex; align-items: center; gap: 8px; margin: 14px 0 0; font-family: var(--mono); font-size: .8rem; color: var(--ink-soft); }
.pqc-note svg { color: var(--success); flex-shrink: 0; }
.pdp-actions { display: flex; flex-direction: column; gap: 10px; padding: 22px; }
.pdp-quote-card .btn { width: 100%; justify-content: center; }
.pdp-ds { padding: 0 22px 22px; }
.pdp-ds-label { display: block; font-family: var(--mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 12px; }
.pdp-ds-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 10px; }
.ds-card { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--line); transition: border-color .2s; }
a.ds-card:hover { border-color: var(--electric); }
.ds-card-ic { width: 38px; height: 38px; display: grid; place-items: center; background: var(--surface-2); color: var(--ink); flex-shrink: 0; }
.ds-card-txt { display: flex; flex-direction: column; line-height: 1.3; min-width: 0; }
.ds-card-txt strong { font-size: .9rem; font-weight: 600; text-transform: uppercase; }
.ds-card-txt small { font-family: var(--mono); font-size: .7rem; color: var(--ink-soft); }
.ds-card-dl { margin-left: auto; color: var(--electric); flex-shrink: 0; }
.ds-card.is-disabled { opacity: .5; cursor: not-allowed; }
.ds-soon { margin-left: auto; font-family: var(--mono); font-size: .56rem; letter-spacing: .04em; text-transform: uppercase; padding: 3px 8px; background: var(--surface-2); color: var(--ink-soft); flex-shrink: 0; }

.pdp-specs { margin-top: clamp(52px,8vw,90px); padding-top: 24px; border-top: 1px solid var(--rule); }
.pdp-specs-head { margin-bottom: 26px; }
.pdp-specs-head .eyebrow { color: var(--ink-soft); }
.pdp-specs-title { margin: 0; text-transform: uppercase; }
.spec-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--ink); }
.spec-card { position: relative; background: var(--paper); padding: 28px; display: flex; flex-direction: column; gap: 4px; }
.spec-ic { width: 42px; height: 42px; display: grid; place-items: center; color: var(--electric); margin-bottom: 14px; border: 1px solid var(--line); }
.spec-card h3 { font-size: 1.02rem; margin: 0 0 6px; text-transform: uppercase; letter-spacing: 0; font-family: var(--mono); font-weight: 600; }
.spec-card p { color: var(--ink-soft); margin: 0; line-height: 1.65; font-size: .96rem; }

.cs-banner { background: var(--impact-bg); color: var(--impact-ink); padding: 30px; border: 1px solid rgba(22,199,230,.3); }
.cs-banner .eyebrow { color: var(--electric); }
.cs-banner .eyebrow::before { background: var(--electric); }

/* =========================================================================
   Blog / prose
   ========================================================================= */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(22px,2.8vw,36px); }
.blog-card .ph { aspect-ratio: 3/2; overflow: hidden; background: var(--surface-2); border: 1px solid var(--ink); margin-bottom: 16px; }
.blog-card .ph img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s cubic-bezier(.2,.7,.2,1); filter: grayscale(.1); }
.blog-card:hover .ph img { transform: scale(1.04); filter: grayscale(0); }
.blog-card .date { font-family: var(--mono); font-size: .74rem; color: var(--electric); }
.blog-card h3 { margin: 10px 0 8px; font-size: 1.3rem; text-transform: uppercase; letter-spacing: -.01em; }
.blog-card p { color: var(--ink-soft); }

.prose { max-width: 780px; }
.prose p { font-size: 1.05rem; line-height: 1.75; }
.prose h2 { margin-top: 1.6em; font-size: clamp(1.4rem,2.4vw,1.9rem); text-transform: uppercase; }
.prose h3 { margin-top: 1.4em; text-transform: uppercase; font-family: var(--mono); font-size: 1rem; letter-spacing: .02em; }
.prose ul { padding-left: 1.2em; margin: 0 0 1em; }
.prose li { margin-bottom: .5em; color: var(--ink-soft); }
.prose a, .spec-table a { color: var(--navy-bright); text-decoration: underline; text-underline-offset: 3px; }
.prose a:hover { color: var(--electric); }
/* distribution */
.dist-stat { display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap; border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); padding: 22px 0; margin: 26px 0 30px; }
.dist-stat .num { font-family: var(--sans); font-weight: 800; font-size: clamp(2.6rem, 7vw, 4.2rem); line-height: 1; letter-spacing: -.03em; }
.dist-stat-lbl { font-family: var(--mono); font-size: .8rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft); }
.dist-regions { display: grid; gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.dist-region { background: var(--paper); padding: 22px 24px; }
.dist-region h3 { font-family: var(--mono); font-size: .74rem; letter-spacing: .1em; text-transform: uppercase; color: var(--electric); margin: 0 0 14px; }
.dist-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.dist-tags span { font-family: var(--mono); font-size: .8rem; letter-spacing: .02em; padding: 6px 11px; border: 1px solid var(--line); border-radius: var(--radius); color: var(--ink); transition: border-color .15s, color .15s; }
.dist-tags span:hover { border-color: var(--electric); color: var(--electric); }

.about-figure { margin: 28px 0; }
.about-figure img { width: 100%; border: 1px solid var(--ink); }
.about-figure figcaption { margin-top: 12px; font-family: var(--mono); font-size: .78rem; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .03em; }

/* =========================================================================
   Forms
   ========================================================================= */
.panel { background: var(--surface); border: 1px solid var(--ink); padding: clamp(24px,4vw,42px); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 7px; }
.field.full { grid-column: 1 / -1; }
.field label { font-family: var(--mono); font-weight: 500; font-size: .74rem; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-soft); }
.field input, .field select, .field textarea { padding: 13px 15px; border: 1px solid var(--line); border-radius: var(--radius); font-size: 1rem; font-family: inherit; background: #fff; color: var(--ink); transition: border-color .15s, box-shadow .15s; }
.field input, .field select { min-height: 52px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--electric); box-shadow: 0 0 0 3px rgba(22,199,230,.18); }
.field textarea { min-height: 140px; resize: vertical; }
.field select { appearance: none; -webkit-appearance: none; -moz-appearance: none; cursor: pointer; padding-right: 44px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23585E66' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; background-size: 16px; }
.form-note { font-family: var(--mono); font-size: .76rem; color: var(--ink-soft); }
.spec-table { width: 100%; border-collapse: collapse; margin: 14px 0; }
.spec-table th, .spec-table td { text-align: left; padding: 12px 0; border-bottom: 1px solid var(--rule); font-size: .92rem; }
.spec-table th { color: var(--ink-soft); font-family: var(--mono); font-weight: 500; font-size: .78rem; text-transform: uppercase; width: 38%; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,60px); align-items: start; }

.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(16px); background: var(--ink); color: var(--paper); padding: 14px 22px; font-family: var(--mono); font-size: .82rem; z-index: 300; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .25s, transform .25s, visibility .25s; }
.toast.show { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }

/* =========================================================================
   Cookie consent theme
   ========================================================================= */
#cc-main {
  --cc-font-family: var(--sans); --cc-bg: var(--surface); --cc-primary-color: var(--ink); --cc-secondary-color: var(--ink-soft);
  --cc-btn-primary-bg: var(--ink); --cc-btn-primary-color: var(--paper); --cc-btn-primary-hover-bg: var(--navy);
  --cc-btn-secondary-bg: var(--surface-2); --cc-btn-secondary-color: var(--ink); --cc-btn-secondary-hover-bg: var(--line);
  --cc-separator-border-color: var(--line); --cc-toggle-on-bg: var(--electric); --cc-cookie-category-block-bg: var(--surface-2);
  --cc-cookie-category-block-bg-hover: var(--line); --cc-link-color: var(--navy-bright);
}
#cc-main .cm, #cc-main .pm { border-radius: var(--radius); }
#cc-main .cm__btn, #cc-main .pm__btn { border-radius: var(--radius); font-weight: 600; }

/* =========================================================================
   Motion
   ========================================================================= */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s cubic-bezier(.2,.7,.2,1), transform .75s cubic-bezier(.2,.7,.2,1); will-change: opacity, transform; }
.reveal.in { opacity: 1; transform: none; }
[data-parallax] { will-change: transform; }
header.nav.scrolled { box-shadow: 0 1px 0 var(--rule); }
header.nav.scrolled .nav-inner { height: 60px; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; }
  [data-parallax] { transform: none !important; }
  * { animation: none !important; scroll-behavior: auto; }
}

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width: 1000px) {
  .spotlight .grid, .craft .grid, .pdp, .thesis-grid, .contact-grid { grid-template-columns: 1fr; }
  .pdp-gallery { position: static; }
  .pdp-gallery .main { aspect-ratio: 16/10; }
  .steps, .collection, .stats, .cards-3, .product-grid, .blog-grid { grid-template-columns: 1fr 1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .mega-grid { grid-template-columns: 1fr 1fr; }
  .mega-dtf { grid-column: 1 / -1; }
}
@media (max-width: 720px) {
  .nav-menu, .nav-right .desktop-only { display: none; }
  .hamburger { display: block; }
  .steps, .collection, .stats, .cards-3, .product-grid, .blog-grid, .form-grid, .foot-grid, .pdp-facts, .spec-grid { grid-template-columns: 1fr; }
  .section-head { grid-template-columns: 1fr; gap: 6px; }
  .section-head .ix { padding-top: 0; }
  .dtf-word { font-size: clamp(3.8rem, 32vw, 7rem); }
  h1 { font-size: clamp(2rem, 11vw, 3rem); }
}
