/* Titan3D — Reusable components.
 * Buttons, cards, badges, inputs, modal, grid, sections.
 * Linear/Modern: multi-layer shadows, glass surfaces, expo-out micro-interactions.
 */

/* ─── Buttons ────────────────────────────────────────────────── */
.t3d-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 18px;
  min-height: 40px;
  border: 0;
  border-radius: var(--radius-md);
  background: var(--accent);
  color: #FFFFFF;
  font-family: inherit;
  font-weight: 600;
  font-size: 0.92rem;
  line-height: 1.2;
  letter-spacing: -0.005em;
  cursor: pointer;
  user-select: none;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  isolation: isolate;
  box-shadow: var(--shadow-glow);
  transition:
    background var(--duration-fast) var(--ease),
    box-shadow var(--duration-fast) var(--ease),
    transform var(--duration-fast) var(--ease),
    opacity var(--duration-fast) var(--ease);
}

/* Hover: subtle lift (translateY -1px) plus brighter background. Text
 * never fades — keep #FFFFFF crisp throughout state transitions. */
.t3d-btn:hover {
  background: var(--accent-hover);
  color: #FFFFFF;
  transform: translateY(-1px);
}
.t3d-btn:active { transform: scale(0.98); }
.t3d-btn:focus-visible {
  outline: 2px solid var(--accent-bright);
  outline-offset: 2px;
}
.t3d-btn:disabled,
.t3d-btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}
.t3d-btn:disabled::before,
.t3d-btn[aria-disabled="true"]::before { display: none; }

.t3d-btn .t3d-icon { width: 16px; height: 16px; flex: none; }

/* Defensive: text inside primary buttons always pure white. Some host
 * panels (e.g. .t3d-account-dashboard__getstarted) sit on translucent
 * indigo backgrounds, and inherited link colors can creep through nested
 * <span> tags. Lock white in. */
.t3d-btn--primary,
.t3d-btn--primary:visited,
.t3d-btn--primary > * {
  color: #FFFFFF;
}

/* Variants */
.t3d-btn--primary {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.10) 0%, rgba(255, 255, 255, 0) 100%),
    var(--accent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.20),
    0 0 0 1px rgba(94, 106, 210, 0.5),
    0 6px 18px rgba(94, 106, 210, 0.36);
}
.t3d-btn--primary:hover {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0) 100%),
    var(--accent-hover);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    0 0 0 1px rgba(94, 106, 210, 0.6),
    0 8px 24px rgba(94, 106, 210, 0.44);
}

.t3d-btn--ghost {
  background: var(--surface);
  color: var(--text-primary);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    var(--shadow-inner-top);
}
.t3d-btn--ghost:hover {
  background: var(--surface-strong);
  color: var(--text-primary);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    var(--shadow-inner-top),
    0 0 24px rgba(94, 106, 210, 0.18);
}

.t3d-btn--subtle {
  background: var(--surface);
  color: var(--text-primary);
  box-shadow:
    inset 0 0 0 1px var(--border),
    var(--shadow-inner-top);
}
.t3d-btn--subtle:hover {
  background: var(--surface-strong);
  box-shadow:
    inset 0 0 0 1px var(--border-strong),
    var(--shadow-inner-top);
}

.t3d-btn--danger {
  background: var(--danger);
  box-shadow:
    0 0 0 1px rgba(239, 68, 68, 0.5),
    0 4px 14px rgba(239, 68, 68, 0.32),
    inset 0 1px 0 0 rgba(255, 255, 255, 0.15);
}
.t3d-btn--danger:hover { background: #F87171; }

.t3d-btn--lg { padding: 14px 24px; min-height: 52px; font-size: 1rem; }
.t3d-btn--sm { padding: 7px 12px; min-height: 32px; font-size: 0.82rem; }
.t3d-btn--block { width: 100%; }

.t3d-btn--icon {
  width: 40px;
  height: 40px;
  padding: 0;
  background: var(--surface);
  box-shadow:
    inset 0 0 0 1px var(--border),
    var(--shadow-inner-top);
}
.t3d-btn--icon:hover {
  background: var(--surface-strong);
  color: var(--accent-bright);
  box-shadow:
    inset 0 0 0 1px var(--border-accent),
    var(--shadow-inner-top);
}

/* Multi-part assembly videos: only the first button is visible; the rest
 * are hidden DOM nodes that share the Fancybox gallery so v1 → v2 plays
 * in sequence (Fancybox auto-advances on <video> ended). */
.t3d-video-part-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* ─── Cards ──────────────────────────────────────────────────── */
.t3d-card {
  position: relative;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0.015) 100%);
  border-radius: var(--radius-2xl);
  padding: var(--space-3);
  isolation: isolate;
  box-shadow: var(--shadow-md);
  transition:
    box-shadow var(--duration-base) var(--ease),
    transform var(--duration-base) var(--ease),
    background var(--duration-base) var(--ease);
  /* spotlight ::before is added via ambient.css [data-spotlight] */
}
.t3d-card > * { position: relative; z-index: 2; }

.t3d-card--hover:hover,
a.t3d-card:hover {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07) 0%, rgba(255, 255, 255, 0.025) 100%);
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

/* Card with accent border treatment */
.t3d-card--accent {
  background: linear-gradient(180deg, var(--accent-soft) 0%, transparent 100%), var(--bg-elevated);
  box-shadow:
    inset 0 0 0 1px var(--border-accent),
    var(--shadow-md);
}

/* Glass card — lighter, more translucent */
.t3d-card--glass {
  background: var(--surface);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

/* ─── Grid utilities ────────────────────────────────────────── */
.t3d-grid { display: grid; gap: var(--space-3); }
.t3d-grid--2 { grid-template-columns: repeat(2, 1fr); }
.t3d-grid--3 { grid-template-columns: repeat(3, 1fr); }
.t3d-grid--4 { grid-template-columns: repeat(4, 1fr); }
.t3d-grid--5 { grid-template-columns: repeat(5, 1fr); }
.t3d-grid--6 { grid-template-columns: repeat(6, 1fr); }
.t3d-grid--bento {
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(180px, auto);
}

/* ─── Badges / pills ─────────────────────────────────────────── */
.t3d-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  background: var(--surface);
  box-shadow: inset 0 0 0 1px var(--border-strong);
  color: var(--text-secondary);
  line-height: 1;
  white-space: nowrap;
}
.t3d-badge--accent {
  background: var(--accent-soft);
  box-shadow: inset 0 0 0 1px var(--border-accent);
  color: var(--accent-bright);
}
.t3d-badge--success {
  background: var(--success-soft);
  box-shadow: inset 0 0 0 1px rgba(16, 185, 129, 0.32);
  color: #34D399;
}
.t3d-badge--danger {
  background: var(--danger-soft);
  box-shadow: inset 0 0 0 1px rgba(239, 68, 68, 0.32);
  color: #FCA5A5;
}
.t3d-badge .t3d-icon { width: 12px; height: 12px; }

/* ─── Section heads ─────────────────────────────────────────── */
.t3d-section__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}
.t3d-section__head--center {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-1);
}
.t3d-section__head h2 { margin: 0; }
.t3d-section__head p { margin: 0; }

.t3d-section__link {
  color: var(--text-muted);
  font-size: 0.9rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: color var(--duration-fast) var(--ease), gap var(--duration-fast) var(--ease);
}
.t3d-section__link:hover {
  color: var(--accent-bright);
  gap: 8px;
}

/* ─── Inputs ────────────────────────────────────────────────── */
.t3d-input,
.t3d-textarea,
.t3d-select,
select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 100%;
  padding: 11px 14px;
  min-height: 44px;
  background: var(--panel);
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  font: inherit;
  letter-spacing: -0.005em;
  transition:
    border-color var(--duration-fast) var(--ease),
    background var(--duration-fast) var(--ease),
    box-shadow var(--duration-fast) var(--ease);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
  outline: none;
}

/* Custom chevron for native selects (since we removed appearance) */
select.t3d-select,
.t3d-shop__bar select,
.t3d-build-hub__sort select,
.woocommerce .woocommerce-ordering select,
select {
  padding-right: 38px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--text-muted) 50%),
    linear-gradient(-45deg, transparent 50%, var(--text-muted) 50%);
  background-position:
    right 18px top 50%,
    right 13px top 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat, no-repeat;
  background-color: var(--panel);
  cursor: pointer;
}
select option {
  background: var(--panel-elevated);
  color: var(--text-primary);
}
.t3d-input::placeholder,
.t3d-textarea::placeholder { color: var(--text-disabled); }
.t3d-input:hover,
.t3d-textarea:hover,
.t3d-select:hover {
  border-color: rgba(255, 255, 255, 0.16);
}
.t3d-input:focus,
.t3d-textarea:focus,
.t3d-select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.03),
    0 0 0 3px rgba(94, 106, 210, 0.18);
}
.t3d-textarea { min-height: 130px; resize: vertical; }
.t3d-form-row { margin-bottom: var(--space-2); }
.t3d-label {
  display: block;
  margin-bottom: 6px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-secondary);
  letter-spacing: -0.005em;
}

/* ─── Search form ───────────────────────────────────────────── */
.t3d-searchform {
  display: flex;
  gap: var(--space-1);
  margin: var(--space-3) 0;
}
.t3d-searchform input[type="search"] {
  flex: 1;
  padding: 11px 14px;
  background: var(--panel);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font: inherit;
  min-height: 44px;
}
.t3d-searchform input[type="search"]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(94, 106, 210, 0.18);
}

/* ─── Page content (long-form) ──────────────────────────────── */
.t3d-page__content,
.t3d-single__content {
  font-size: 1.02rem;
  line-height: 1.75;
  color: var(--text-secondary);
  max-width: 70ch;
}
/* WC pages need full width — they're layout, not prose. */
body.woocommerce-cart .t3d-page__content,
body.woocommerce-checkout .t3d-page__content,
body.woocommerce-account .t3d-page__content {
  max-width: none !important;
  font-size: inherit;
  line-height: inherit;
  color: inherit;
}
.t3d-page__content h2,
.t3d-single__content h2 { margin-top: var(--space-4); color: var(--text-primary); }
.t3d-page__content h3,
.t3d-single__content h3 { margin-top: var(--space-3); color: var(--text-primary); }
/* Underline only inline anchors that live inside body-copy elements
 * (paragraphs, blockquotes, definition descriptions). We deliberately
 * skip <li> in the selector — many nav menus use <ul><li><a> and would
 * inherit the underline. List anchors should opt in via .t3d-prose-link
 * if needed. Buttons/cards explicitly excluded. */
.t3d-page__content :is(p, blockquote, dd) a:not(.t3d-btn):not(.t3d-account-card),
.t3d-single__content :is(p, blockquote, dd) a:not(.t3d-btn):not(.t3d-account-card) {
  color: var(--accent-bright);
  border-bottom: 1px solid currentColor;
}

/* ─── Archive header ─────────────────────────────────────────── */
.t3d-archive__header {
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border);
}

/* ─── 404 ────────────────────────────────────────────────────── */
.t3d-404 {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-7) var(--space-3);
  gap: var(--space-2);
}
.t3d-404 h1 {
  font-size: clamp(4rem, 11vw, 8.5rem);
  margin: 0;
  letter-spacing: -0.04em;
  line-height: 1;
}
.t3d-404 p {
  color: var(--text-muted);
  font-size: 1.1rem;
  margin: 0;
  max-width: 50ch;
}
.t3d-404__actions {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
  justify-content: center;
  margin-top: var(--space-2);
}
.t3d-404__search {
  width: 100%;
  max-width: 480px;
  margin-top: var(--space-1);
}

/* ─── Inline icon helper ────────────────────────────────────── */
.t3d-icon {
  display: inline-block;
  vertical-align: middle;
  width: 22px; height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex: none;
}

/* ─── Modal ──────────────────────────────────────────────────── */
.t3d-modal {
  position: fixed;
  inset: 0;
  /* High z-index so modal sits above all positioned content + WC blocks */
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3);
  animation: t3d-fade-in 200ms var(--ease);
  /* Don't let any ancestor's transform/filter trap us — paint as own layer. */
  isolation: isolate;
}
.t3d-modal[hidden] { display: none; }
.t3d-modal__backdrop {
  position: absolute;
  inset: 0;
  /* Strong backdrop — opaque enough to fully obscure content behind */
  background: rgba(2, 2, 3, 0.85);
  backdrop-filter: blur(12px) saturate(120%);
  -webkit-backdrop-filter: blur(12px) saturate(120%);
}
.t3d-modal__panel {
  position: relative;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.02) 100%), var(--bg-elevated);
  border-radius: var(--radius-2xl);
  padding: var(--space-4);
  max-width: 480px;
  width: 100%;
  max-height: calc(100vh - var(--space-4));
  overflow-y: auto;
  box-shadow: var(--shadow-xl);
  animation: t3d-pop-in 300ms var(--ease);
}
.t3d-modal__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  background: transparent;
  border: 0;
  color: var(--text-muted);
  font-size: 1.4rem;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);
}
.t3d-modal__close:hover { color: var(--text-primary); background: var(--surface); }
.t3d-modal__heading {
  margin: 0 0 var(--space-2);
  font-size: 1.35rem;
  letter-spacing: -0.02em;
}
.t3d-modal__body { color: var(--text-secondary); margin-bottom: var(--space-3); line-height: 1.6; }
.t3d-modal__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
}
.t3d-modal__actions .t3d-btn {
  width: 100%;
  white-space: normal;
  text-align: center;
  line-height: 1.3;
  /* Allow long copy (e.g. "Upgrade to Platinum ($29/mo · gets you 8 credits/mo)") to wrap */
}
body.t3d-modal-open { overflow: hidden; }

@keyframes t3d-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes t3d-pop-in {
  from { opacity: 0; transform: scale(0.96) translateY(8px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}

/* ─── Notifications/banners (generic) ──────────────────────── */
.t3d-notice {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  display: flex;
  align-items: flex-start;
  gap: var(--space-1);
  margin-bottom: var(--space-3);
}
.t3d-notice--info {
  background: var(--accent-wash);
  box-shadow: inset 0 0 0 1px var(--border-accent);
  color: var(--text-primary);
}
.t3d-notice--success {
  background: var(--success-soft);
  box-shadow: inset 0 0 0 1px rgba(16, 185, 129, 0.30);
  color: #34D399;
}
.t3d-notice--error {
  background: var(--danger-soft);
  box-shadow: inset 0 0 0 1px rgba(239, 68, 68, 0.30);
  color: #FCA5A5;
}

/* ─── Responsive: collapse grids ──────────────────────────── */
@media (max-width: 1280px) {
  .t3d-grid--5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1024px) {
  .t3d-grid--4 { grid-template-columns: repeat(3, 1fr); }
  .t3d-grid--6 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .t3d-grid--2,
  .t3d-grid--3,
  .t3d-grid--4,
  .t3d-grid--5 { grid-template-columns: repeat(2, 1fr); }
  .t3d-grid--6 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .t3d-grid--2,
  .t3d-grid--3,
  .t3d-grid--4,
  .t3d-grid--5,
  .t3d-grid--6 { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════════════════
 * Industrial skeuomorphic variants
 *
 * Opt-in dark industrial aesthetic for buttons and cards. Buttons feel like
 * physical spring-loaded keys; cards feel like raised bolted hardware modules.
 * These variants are MUTUALLY EXCLUSIVE with the regular .t3d-btn--primary /
 * .t3d-btn--ghost / .t3d-card--accent variants — pick one or the other on a
 * given element. Tokens live in tokens.css under "Industrial skeuomorphic".
 *
 * Usage:
 *
 *   Buttons:
 *     <button class="t3d-btn t3d-btn--ind-primary">PRIMARY CTA</button>
 *     <button class="t3d-btn t3d-btn--ind-secondary">Secondary</button>
 *     <a href="#" class="t3d-btn t3d-btn--ind-ghost">Navigate</a>
 *
 *   Cards:
 *     <div class="t3d-card t3d-card--ind t3d-card--hover">…</div>
 *     <a class="t3d-card t3d-card--ind-elevated">…</a>
 *
 *   Decorations (drop in as children of any t3d-card--ind* card):
 *     <span class="t3d-ind-screws" aria-hidden="true"></span>
 *     <span class="t3d-ind-vents"  aria-hidden="true">
 *       <span></span><span></span><span></span>
 *     </span>
 *     <span class="t3d-ind-hole"   aria-hidden="true"></span>
 *
 *   Card icon housing (round raised disc that scales+rotates on card hover):
 *     <span class="t3d-ind-icon-housing">
 *       <svg class="t3d-icon">…</svg>
 *     </span>
 *
 *   CTA arrow that shifts right on parent hover:
 *     <span>Launch</span>
 *     <svg class="t3d-icon t3d-ind-arrow">…</svg>
 * ─────────────────────────────────────────────────────────────────────────── */

/* ─── Industrial buttons — pill base (size, type, focus) ───── */
.t3d-btn--ind-primary,
.t3d-btn--ind-secondary,
.t3d-btn--ind-ghost {
  min-height: 56px;
  /* Uppercase text has no descenders, so the line-box's descender slot pushes
   * the visual center up. Tighten line-height to 1 and offset padding (+1 top,
   * -1 bottom) so caps align to the button's true center. */
  padding: 17px 32px 15px;
  border: 0;
  border-radius: 999px;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  transition:
    box-shadow var(--duration-fast) var(--industrial-ease-standard),
    transform  var(--duration-fast) var(--industrial-ease-standard),
    color      var(--duration-fast) var(--industrial-ease-standard),
    filter     var(--duration-fast) var(--industrial-ease-standard);
}
.t3d-btn--ind-primary:disabled,
.t3d-btn--ind-secondary:disabled,
.t3d-btn--ind-ghost:disabled,
.t3d-btn--ind-primary[aria-disabled="true"],
.t3d-btn--ind-secondary[aria-disabled="true"],
.t3d-btn--ind-ghost[aria-disabled="true"] {
  opacity: 0.5;
  pointer-events: none;
  transform: none;
  filter: none;
}

/* ─── Primary — coral pillow with red halo ─────────────────── */
.t3d-btn--ind-primary {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0) 60%),
    var(--industrial-accent);
  color: var(--industrial-accent-foreground);
  box-shadow: var(--industrial-shadow-accent);
}
.t3d-btn--ind-primary:hover {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0) 60%),
    var(--industrial-accent);
  color: var(--industrial-accent-foreground);
  filter: brightness(1.06);
  transform: translateY(-1px);
}
.t3d-btn--ind-primary:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 2px var(--industrial-bg),
    0 0 0 4px var(--industrial-ring),
    var(--industrial-shadow-accent);
}
.t3d-btn--ind-primary:active {
  filter: none;
  transform: translateY(1px);
  box-shadow: var(--industrial-shadow-accent-pressed);
}

/* ─── Secondary — dark pillow surface ──────────────────────── */
.t3d-btn--ind-secondary {
  background: var(--industrial-surface);
  color: var(--industrial-text);
  box-shadow: var(--industrial-shadow-card);
}
.t3d-btn--ind-secondary:hover {
  background: var(--industrial-surface);
  color: var(--industrial-accent);
  transform: translateY(-1px);
  box-shadow: var(--industrial-shadow-floating);
}
.t3d-btn--ind-secondary:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 2px var(--industrial-bg),
    0 0 0 4px var(--industrial-ring),
    var(--industrial-shadow-card);
}
.t3d-btn--ind-secondary:active {
  color: var(--industrial-text);
  transform: translateY(1px);
  box-shadow: var(--industrial-shadow-pressed);
}

/* ─── Shape modifier — flatten any t3d-btn--ind-* to a rect ── */
/* Compose with a color variant: <button class="t3d-btn t3d-btn--ind-primary t3d-btn--ind-rect">
 * Pill (999px) is the default; this overrides only border-radius. */
.t3d-btn--ind-rect { border-radius: 12px; }

/* ─── Size modifier — small industrial buttons ───────────── */
/* Compose: <button class="t3d-btn t3d-btn--ind-primary t3d-btn--ind-rect t3d-btn--ind-sm"> */
.t3d-btn--ind-sm {
  min-height: 40px;
  padding: 11px 22px 9px;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
}

/* ─── Ghost — transparent, dark pillow on hover ────────────── */
.t3d-btn--ind-ghost {
  padding: 15px 28px 13px;
  background: transparent;
  color: var(--industrial-text-muted);
  box-shadow: none;
}
.t3d-btn--ind-ghost:hover {
  background: var(--industrial-surface);
  color: var(--industrial-text);
  transform: none;
  box-shadow: var(--industrial-shadow-card);
}
.t3d-btn--ind-ghost:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 2px var(--industrial-bg),
    0 0 0 4px var(--industrial-ring);
}
.t3d-btn--ind-ghost:active {
  background: var(--industrial-surface);
  color: var(--industrial-text);
  transform: translateY(1px);
  box-shadow: var(--industrial-shadow-pressed);
}

/* ─── Industrial cards — soft pillow modules ───────────────── */
.t3d-card--ind,
.t3d-card--ind-elevated {
  position: relative;
  background: var(--industrial-surface);
  color: var(--industrial-text);
  border: 0;
  border-radius: var(--radius-3xl);
  padding: var(--space-3);
  isolation: isolate;
  box-shadow: var(--industrial-shadow-card);
  transition:
    transform  var(--duration-base) var(--industrial-ease-standard),
    box-shadow var(--duration-base) var(--industrial-ease-standard);
}
.t3d-card--ind > *,
.t3d-card--ind-elevated > * { position: relative; z-index: 2; }

/* Lift on hover, but only when interactive (matches .t3d-card pattern) */
.t3d-card--ind.t3d-card--hover:hover,
a.t3d-card--ind:hover,
button.t3d-card--ind:hover {
  transform: translateY(-4px);
  box-shadow: var(--industrial-shadow-floating);
}

/* Elevated — featured/pricing modules: bigger, stronger lift */
.t3d-card--ind-elevated {
  padding: var(--space-4);
  border-radius: var(--radius-4xl);
  box-shadow: var(--industrial-shadow-floating);
}
.t3d-card--ind-elevated.t3d-card--hover:hover,
a.t3d-card--ind-elevated:hover,
button.t3d-card--ind-elevated:hover {
  transform: translateY(-6px);
}

/* ─── Card decorations (child overlays) ────────────────────── */

/* 4 corner screws — tiny subtle metal dots, one per corner. */
.t3d-ind-screws {
  pointer-events: none;
  position: absolute;
  inset: 0;
  border-radius: inherit;
  z-index: 1;
  background:
    radial-gradient(circle at 14px 14px,
      rgba(0, 0, 0, 0.55) 1.4px,
      rgba(255, 255, 255, 0.06) 2.4px,
      transparent 3.2px),
    radial-gradient(circle at calc(100% - 14px) 14px,
      rgba(0, 0, 0, 0.55) 1.4px,
      rgba(255, 255, 255, 0.06) 2.4px,
      transparent 3.2px),
    radial-gradient(circle at 14px calc(100% - 14px),
      rgba(0, 0, 0, 0.55) 1.4px,
      rgba(255, 255, 255, 0.06) 2.4px,
      transparent 3.2px),
    radial-gradient(circle at calc(100% - 14px) calc(100% - 14px),
      rgba(0, 0, 0, 0.55) 1.4px,
      rgba(255, 255, 255, 0.06) 2.4px,
      transparent 3.2px);
}

/* 3 vent slots — small subtle ticks, top-right. Requires 3 child <span>s. */
.t3d-ind-vents {
  position: absolute;
  top: 18px;
  right: 18px;
  display: flex;
  gap: 3px;
  pointer-events: none;
  z-index: 1;
}
.t3d-ind-vents > span {
  display: block;
  width: 2px;
  height: 16px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.5);
}

/* Punched hanging hole — top-center, recessed. */
.t3d-ind-hole {
  pointer-events: none;
  position: absolute;
  top: 18px;
  left: 50%;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--industrial-recessed);
  box-shadow: var(--industrial-shadow-recessed);
  transform: translateX(-50%);
  z-index: 1;
}

/* ─── Card child interactions ──────────────────────────────── */

/* Round raised icon disc — same pillow surface as card. */
.t3d-ind-icon-housing {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--industrial-surface);
  color: var(--industrial-accent);
  box-shadow: var(--industrial-shadow-card);
  transition: transform 200ms var(--industrial-ease-mechanical);
}
.t3d-card--ind:hover .t3d-ind-icon-housing,
.t3d-card--ind-elevated:hover .t3d-ind-icon-housing {
  transform: scale(1.06) rotate(4deg);
}

/* CTA arrow — translates right on parent button/card hover, snaps back on press. */
.t3d-ind-arrow {
  transition: transform 200ms var(--industrial-ease-standard);
}
.t3d-btn--ind-primary:hover   .t3d-ind-arrow,
.t3d-btn--ind-secondary:hover .t3d-ind-arrow,
.t3d-btn--ind-ghost:hover     .t3d-ind-arrow,
.t3d-card--ind:hover          .t3d-ind-arrow,
.t3d-card--ind-elevated:hover .t3d-ind-arrow {
  transform: translateX(4px);
}
.t3d-btn--ind-primary:active   .t3d-ind-arrow,
.t3d-btn--ind-secondary:active .t3d-ind-arrow,
.t3d-btn--ind-ghost:active     .t3d-ind-arrow {
  transform: translateX(0);
}
