/* LockGrip Elite special page styles. Loaded only where matching contact/stockist classes are likely used. */


/* -------------------------------
   CONTACT PAGE
-------------------------------- */
.lg-contact-page {
  --bg: #050505;
  --panel: #0d0d10;
  --panel2: #111116;
  --text: #fff;
  --muted: #b9bcc6;
  --line: rgba(255,255,255,0.08);
  --accent: #f68720;
  --accent2: #f68720;
  --shadow: 0 14px 34px rgba(0,0,0,0.38);
  background: #000;
  color: var(--text);
  font-family: Arial, Helvetica, sans-serif;
  padding: 0;
  margin: 0;
}

.lg-contact-wrap { max-width: 420px; margin: 0 auto; background: #000; }
.lg-contact-inner { padding: 24px 16px 0; }
.lg-page-title { font-size: 28px; font-weight: 800; line-height: 1.1; margin: 0 0 34px; color: #fff; }
.lg-intro { text-align: center; padding: 6px 6px 24px; }
.lg-intro p { margin: 0 0 10px; color: #f3f3f3; font-size: 14px; line-height: 1.6; }
.lg-intro p.sub { color: #d1d1d6; margin-bottom: 0; }
.lg-cards { display: grid; gap: 12px; margin-bottom: 28px; }

.lg-info-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015)), radial-gradient(circle at right center, rgba(246,135,32,0.08), transparent 35%);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 16px;
  padding: 16px 14px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: var(--shadow);
}

.lg-icon-box { width: 42px; height: 42px; min-width: 42px; border-radius: 12px; background: #f2f2f2; display: flex; align-items: center; justify-content: center; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.05); }
.lg-icon-box svg { width: 20px; height: 20px; fill: #444; }
.lg-card-text .label { color: var(--accent2); font-size: 11px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 4px; }
.lg-card-text .small { color: #c7c9d0; font-size: 12px; margin-bottom: 8px; }
.lg-card-text a,
.lg-card-text span { color: #fff; font-size: 15px; font-weight: 600; text-decoration: none; word-break: break-word; }
.lg-divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent); margin: 16px 0 22px; }
.lg-retail { text-align: center; padding: 2px 8px 28px; }
.lg-section-kicker { color: var(--accent2); font-size: 11px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; margin-bottom: 14px; }
.lg-retail h2 { font-size: 29px; line-height: 1.18; margin: 0 0 12px; font-weight: 800; color: #fff; }
.lg-retail p { color: #d1d1d6; font-size: 14px; line-height: 1.6; margin: 0 auto 20px; max-width: 260px; }

.lg-contact-page .lg-btn {
  display: inline-block;
  background: linear-gradient(180deg, #f68720, var(--accent));
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  padding: 15px 22px;
  border-radius: 999px;
  box-shadow: 0 12px 24px rgba(246,135,32,0.28);
}

.lg-faq-section {
  margin-top: 2px;
  background: radial-gradient(circle at left bottom, rgba(246,135,32,0.10), transparent 40%), linear-gradient(180deg, #0b0b10 0%, #09090d 100%);
  border-top: 1px solid rgba(255,255,255,0.05);
  border-bottom: 2px solid rgba(246,135,32,0.65);
  padding: 16px 12px 14px;
}

.lg-faq-grid { display: grid; grid-template-columns: 96px 1fr; gap: 12px; align-items: start; }
.lg-faq-image { border-radius: 8px; overflow: hidden; background: #111; min-height: 146px; box-shadow: var(--shadow); }
.lg-faq-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.lg-faq-right .lg-section-kicker { margin-bottom: 10px; text-align: center; }
.lg-accordion { display: grid; gap: 8px; }
.lg-accordion details { background: #141720; border: 1px solid rgba(255,255,255,0.08); border-radius: 10px; overflow: hidden; }
.lg-accordion details[open] { border-color: rgba(246,135,32,0.35); background: #171a24; }
.lg-accordion summary { list-style: none; cursor: pointer; padding: 13px 36px 13px 12px; position: relative; font-size: 14px; font-weight: 700; color: #fff; }
.lg-accordion summary::-webkit-details-marker { display: none; }
.lg-accordion summary:after { content: "+"; position: absolute; right: 12px; top: 50%; transform: translateY(-50%); color: #fff; font-size: 18px; font-weight: 400; opacity: .9; }
.lg-accordion details[open] summary:after { content: "×"; color: var(--accent2); }
.lg-accordion .content { padding: 0 12px 14px; color: #d4d7de; font-size: 13px; line-height: 1.55; }

.lg-cta { padding: 20px 16px 22px; background: radial-gradient(circle at right center, rgba(246,135,32,0.13), transparent 35%), #08090d; }
.lg-cta h2 { margin: 0; font-size: 28px; line-height: .98; font-weight: 900; text-transform: uppercase; letter-spacing: -.8px; font-style: italic; }
.lg-cta h2 .white { color: #fff; display: block; }
.lg-cta h2 .orange { color: var(--accent); display: block; }
.lg-cta p { color: #d5d7dd; font-size: 14px; margin: 10px 0 18px; }
.lg-cta .lg-btn { display: block; text-align: center; width: 100%; padding: 16px 20px; box-sizing: border-box; margin-bottom: 10px; }
.lg-cta .ship { color: #efefef; font-size: 13px; }

@media (min-width: 768px) {
  .lg-contact-wrap { max-width: 1100px; }
  .lg-contact-inner { padding: 40px 28px 0; }
  .lg-page-title { font-size: 42px; margin-bottom: 28px; }
  .lg-cards { grid-template-columns: 1fr 1fr; }
  .lg-retail p { max-width: 600px; }
  .lg-faq-grid { grid-template-columns: 220px 1fr; }
  .lg-faq-image { min-height: 220px; }
}

/* -------------------------------
   STOCKIST / WHERE TO BUY SIMPLE PAGE
-------------------------------- */
.lockgrip-where { color: #fff; max-width: 900px; }
.lockgrip-where h1 { font-size: 32px; margin-bottom: 20px; }
.lockgrip-where h2 { margin-top: 28px; margin-bottom: 10px; }
.lockgrip-btns { display: flex; gap: 12px; margin: 20px 0; flex-wrap: wrap; }
.lockgrip-cta { margin-top: 40px; padding-top: 10px; }
.lockgrip-cta h2 { margin-bottom: 10px; }
.lg-sub { opacity: .8; margin: 15px 0; }
