/* London Carpets Theme - main.css v4.0
   UK English. No em-dashes in copy. Elementor compatible.
   All classes prefixed lc- to avoid conflicts.
*/

/* ============================================================
   CUSTOM PROPERTIES
   ============================================================ */
:root {
  --lc-onyx:      #0E0D0B;
  --lc-onyx-2:    #161512;
  --lc-onyx-3:    #1F1E1A;
  --lc-onyx-4:    #2A2924;
  --lc-parchment: #F5EFE4;
  --lc-gold:      #C8A96E;
  --lc-gold-2:    #E0C689;
  --lc-mist:      rgba(245,239,228,0.55);
  --lc-muted:     rgba(245,239,228,0.38);
  --lc-font-display: 'Playfair Display', Georgia, serif;
  --lc-font-body:    'Outfit', sans-serif;
  --lc-ease:      cubic-bezier(.25,.1,.25,1);
  --lc-ease-out:  cubic-bezier(0,.4,0,1);
  --lc-max-w:     1360px;
}

/* ============================================================
   RESET AND BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }

body,
.lc-body {
  background: var(--lc-onyx);
  color: var(--lc-parchment);
  font-family: var(--lc-font-body);
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
  cursor: none;
}

/* Elementor editor - restore normal cursor */
body.elementor-editor-active,
body.elementor-editor-active * {
  cursor: default !important;
}
body.elementor-editor-active .lc-cursor,
body.elementor-editor-active .lc-cursor-ring { display: none; }

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }

/* Prevent horizontal scroll globally */
html, body { max-width: 100%; overflow-x: hidden; }

.screen-reader-text {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.lc-cursor {
  position: fixed; top: 0; left: 0;
  width: 8px; height: 8px;
  background: var(--lc-gold);
  border-radius: 50%;
  pointer-events: none; z-index: 99999;
  transform: translate(-50%,-50%);
  transition: width .3s var(--lc-ease), height .3s var(--lc-ease);
}
.lc-cursor.on { width: 16px; height: 16px; background: var(--lc-gold-2); }
.lc-cursor-ring {
  position: fixed; top: 0; left: 0;
  width: 36px; height: 36px;
  border: 1px solid rgba(200,169,110,.45);
  border-radius: 50%;
  pointer-events: none; z-index: 99998;
  transform: translate(-50%,-50%);
  transition: transform .45s var(--lc-ease-out), width .4s var(--lc-ease), height .4s var(--lc-ease);
}
.lc-cursor-ring.on { width: 56px; height: 56px; }

/* ============================================================
   TYPOGRAPHY UTILITIES
   ============================================================ */
.lc-display { font-family: var(--lc-font-display); font-weight: 300; line-height: 1.05; }
.lc-display em { font-style: italic; color: var(--lc-gold-2); }
.lc-display--xl { font-size: clamp(3.8rem, 8vw, 8.5rem); }
.lc-display--md { font-size: clamp(2rem, 3.5vw, 3.5rem); }
.lc-label {
  font-family: var(--lc-font-body); font-size: .62rem;
  font-weight: 400; letter-spacing: .28em; text-transform: uppercase; color: var(--lc-gold);
}
.lc-body-lg { font-size: 1.05rem; line-height: 1.85; color: var(--lc-mist); }
.lc-body-sm { font-size: .88rem; line-height: 1.75; color: var(--lc-muted); }
.lc-required { color: var(--lc-gold); }

/* ============================================================
   LAYOUT
   ============================================================ */
.lc-wrap { max-width: var(--lc-max-w); margin: 0 auto; padding: 0 60px; }
.lc-section { padding: 140px 0; }

/* ============================================================
   BUTTONS
   ============================================================ */
.lc-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--lc-font-body); font-size: .7rem; font-weight: 400;
  letter-spacing: .22em; text-transform: uppercase;
  padding: 17px 38px;
  border: 1px solid currentColor;
  transition: background .4s var(--lc-ease), color .4s var(--lc-ease), transform .25s var(--lc-ease);
  cursor: pointer; white-space: nowrap; text-decoration: none;
}
.lc-btn:hover { transform: translateY(-2px); }
.lc-btn--gold  { color: var(--lc-gold);      border-color: var(--lc-gold); }
.lc-btn--gold:hover  { background: var(--lc-gold);      color: var(--lc-onyx); }
.lc-btn--pale  { color: var(--lc-parchment); border-color: rgba(245,239,228,.35); }
.lc-btn--pale:hover  { background: var(--lc-parchment); color: var(--lc-onyx); }
.lc-btn--sm    { padding: 12px 28px; font-size: .65rem; }
.lc-btn svg    { flex-shrink: 0; }

/* ============================================================
   IMAGE PLACEHOLDER (shown when no image set in Customiser)
   ============================================================ */
.lc-image-placeholder {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(245,239,228,.06);
  border: 2px dashed rgba(200,169,110,.3);
  padding: 24px; text-align: center;
}
.lc-image-placeholder p {
  font-size: .75rem; color: rgba(200,169,110,.7);
  line-height: 1.6; font-family: var(--lc-font-body);
}
.lc-image-placeholder--small p { font-size: .65rem; }

/* ============================================================
   COOKIE CONSENT BANNER
   ============================================================ */
.lc-cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--lc-onyx-3);
  border-top: 1px solid rgba(200,169,110,.2);
  z-index: 8000;
  padding: 20px 40px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap;
  transform: translateY(100%);
  transition: transform .5s var(--lc-ease-out);
}
.lc-cookie-banner.lc-visible { transform: translateY(0); }
.lc-cookie-banner__text { flex: 1; min-width: 280px; }
.lc-cookie-banner__text p { font-size: .8rem; color: var(--lc-mist); line-height: 1.65; }
.lc-cookie-banner__text a { color: var(--lc-gold); text-decoration: underline; }
.lc-cookie-banner__actions { display: flex; gap: 10px; flex-wrap: wrap; flex-shrink: 0; }
.lc-cookie-btn {
  font-family: var(--lc-font-body); font-size: .62rem; font-weight: 400;
  letter-spacing: .15em; text-transform: uppercase;
  padding: 10px 20px; border: 1px solid var(--lc-gold);
  cursor: pointer; transition: background .3s, color .3s;
  white-space: nowrap; background: transparent;
}
.lc-cookie-btn--accept { background: var(--lc-gold); color: var(--lc-onyx); }
.lc-cookie-btn--accept:hover { background: var(--lc-gold-2); border-color: var(--lc-gold-2); }
.lc-cookie-btn--reject { color: var(--lc-gold); }
.lc-cookie-btn--reject:hover { background: rgba(200,169,110,.1); }
.lc-cookie-btn--manage { color: var(--lc-muted); border-color: rgba(200,169,110,.3); font-size: .58rem; }
.lc-cookie-btn--manage:hover { color: var(--lc-parchment); border-color: var(--lc-gold); }

/* Cookie modal */
.lc-cookie-modal {
  position: fixed; inset: 0;
  background: rgba(14,13,11,.88); backdrop-filter: blur(12px);
  z-index: 8500; display: flex; align-items: center; justify-content: center;
  padding: 20px 16px;
  overflow-y: auto;
}
.lc-cookie-modal[style*="display:none"] { display: none !important; }
.lc-cookie-modal__box {
  background: var(--lc-onyx-3); border: 1px solid rgba(200,169,110,.18);
  max-width: 600px; width: 100%; max-height: 90vh; overflow-y: auto;
  margin: auto;
}
.lc-cookie-modal__header {
  padding: 36px 40px 24px;
  border-bottom: 1px solid rgba(200,169,110,.1);
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; background: var(--lc-onyx-3); z-index: 2;
}
.lc-cookie-modal__header h2 {
  font-family: var(--lc-font-display); font-size: 1.5rem;
  font-weight: 400; color: var(--lc-parchment);
}
.lc-cookie-modal__close {
  background: none; border: none; cursor: pointer;
  color: var(--lc-muted); font-size: 1.6rem; line-height: 1;
  transition: color .3s; padding: 4px;
}
.lc-cookie-modal__close:hover { color: var(--lc-parchment); }
.lc-cookie-modal__body { padding: 28px 40px; display: flex; flex-direction: column; gap: 24px; }
.lc-cookie-cat { border-bottom: 1px solid rgba(245,239,228,.08); padding-bottom: 20px; }
.lc-cookie-cat:last-child { border-bottom: none; padding-bottom: 0; }
.lc-cookie-cat__head {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px;
}
.lc-cookie-cat__head h3 {
  font-family: var(--lc-font-display); font-size: 1rem;
  font-weight: 400; color: var(--lc-parchment);
}
.lc-cookie-cat p { font-size: .8rem; color: var(--lc-muted); line-height: 1.65; }
.lc-cookie-always-on {
  font-size: .58rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--lc-gold); padding: 4px 10px; border: 1px solid rgba(200,169,110,.3);
}
/* Toggle */
.lc-toggle { position: relative; width: 44px; height: 24px; display: inline-block; cursor: pointer; }
.lc-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.lc-toggle__track {
  position: absolute; inset: 0;
  background: rgba(245,239,228,.12); border: 1px solid rgba(245,239,228,.2);
  transition: background .3s;
}
.lc-toggle input:checked + .lc-toggle__track { background: var(--lc-gold); border-color: var(--lc-gold); }
.lc-toggle__track::after {
  content: ''; position: absolute;
  width: 18px; height: 18px; top: 2px; left: 2px;
  background: var(--lc-parchment); transition: transform .3s var(--lc-ease);
}
.lc-toggle input:checked + .lc-toggle__track::after { transform: translateX(20px); }
.lc-cookie-modal__footer {
  padding: 16px 40px 32px;
  display: flex; justify-content: flex-end;
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.lc-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 900;
  padding: 32px 60px;
  display: flex; align-items: center; justify-content: space-between;
  transition: padding .4s var(--lc-ease), background .4s var(--lc-ease), border-color .4s var(--lc-ease);
  border-bottom: 1px solid transparent;
}
.lc-nav.lc-nav--scrolled {
  padding: 18px 60px;
  background: rgba(14,13,11,.96);
  backdrop-filter: blur(20px);
  border-bottom-color: rgba(200,169,110,.1);
}
.lc-nav__logo {
  font-family: var(--lc-font-display); font-size: 1.5rem;
  font-weight: 400; color: var(--lc-parchment); line-height: 1.1;
}
.lc-nav__logo span {
  display: block; font-family: var(--lc-font-body); font-size: .5rem;
  font-weight: 300; letter-spacing: .38em; text-transform: uppercase;
  color: var(--lc-gold); margin-top: 5px;
}
.lc-nav__links { display: flex; align-items: center; gap: 36px; }
.lc-nav__links a {
  font-size: .65rem; font-weight: 400; letter-spacing: .18em;
  text-transform: uppercase; color: var(--lc-mist); transition: color .3s;
}
.lc-nav__links a:hover { color: var(--lc-gold); }
.lc-nav__contact-btn {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--lc-font-body); font-size: .62rem; font-weight: 400;
  letter-spacing: .14em; text-transform: lowercase;
  color: var(--lc-gold);
  padding: 10px 22px;
  border: 1px solid rgba(200,169,110,.35);
  transition: background .3s var(--lc-ease), border-color .3s var(--lc-ease), color .3s var(--lc-ease), transform .25s var(--lc-ease);
  white-space: nowrap;
}
.lc-nav__contact-btn svg { flex-shrink: 0; opacity: .8; transition: opacity .3s; }
.lc-nav__contact-btn:hover {
  background: rgba(200,169,110,.08);
  border-color: var(--lc-gold);
  color: var(--lc-gold-2);
  transform: translateY(-1px);
}
.lc-nav__contact-btn:hover svg { opacity: 1; }
/* When scrolled - slightly more visible */
.lc-nav--scrolled .lc-nav__contact-btn {
  border-color: rgba(200,169,110,.5);
}
.lc-hamburger {
  display: none; flex-direction: column; gap: 6px;
  cursor: pointer; padding: 4px; background: none; border: none;
}
.lc-hamburger span {
  display: block; width: 26px; height: 1px;
  background: var(--lc-parchment);
  transition: transform .4s var(--lc-ease), opacity .3s;
}
.lc-mob-nav {
  position: fixed; inset: 0;
  background: rgba(14,13,11,.98); backdrop-filter: blur(32px);
  z-index: 850; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 36px;
  transform: translateY(-100%); transition: transform .6s var(--lc-ease-out);
  overflow-y: auto; padding: 100px 32px 60px;
}
.lc-mob-nav.lc-mob-nav--open { transform: translateY(0); }
.lc-mob-nav a {
  font-family: var(--lc-font-display); font-size: 2rem;
  font-weight: 300; color: var(--lc-parchment); font-style: italic; transition: color .3s;
}
.lc-mob-nav a:hover { color: var(--lc-gold); }
.lc-mob-nav__links {
  display: flex; flex-direction: column; align-items: center; gap: 28px;
}

/* Separator line between nav links and contact block */
.lc-mob-nav__contact {
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  margin-top: 8px;
  padding-top: 36px;
  border-top: 1px solid rgba(200,169,110,.18);
  width: 100%; max-width: 340px;
  text-align: center;
}

.lc-mob-nav__contact-label {
  font-family: var(--lc-font-body);
  font-size: .55rem;
  font-weight: 400;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(200,169,110,.6);
}

.lc-mob-nav__email {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--lc-font-body) !important;
  font-size: 1rem !important;
  font-weight: 300;
  font-style: normal !important;
  letter-spacing: .04em;
  color: var(--lc-parchment) !important;
  text-transform: lowercase;
  padding: 18px 32px;
  border: 1px solid rgba(200,169,110,.3);
  width: 100%;
  justify-content: center;
  transition: background .3s var(--lc-ease), border-color .3s var(--lc-ease), color .3s var(--lc-ease);
}
.lc-mob-nav__email svg { flex-shrink: 0; color: var(--lc-gold); }
.lc-mob-nav__email:hover {
  background: rgba(200,169,110,.08);
  border-color: var(--lc-gold);
  color: var(--lc-gold-2) !important;
}

/* ============================================================
   HERO
   ============================================================ */
.lc-hero {
  position: relative; height: 100vh; min-height: 700px;
  display: flex; flex-direction: column; justify-content: flex-end;
  overflow: hidden;
}
.lc-hero__bg {
  position: absolute; inset: 0;
  background: url('') center/cover no-repeat var(--lc-onyx-3);
  transform: scale(1.08);
  animation: lcHeroZoom 14s var(--lc-ease-out) forwards;
}
.lc-hero__bg::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(165deg, rgba(14,13,11,.1) 0%, rgba(14,13,11,.82) 70%);
}
@keyframes lcHeroZoom { to { transform: scale(1); } }
.lc-hero__content { position: relative; z-index: 2; padding: 0 80px 120px; }
.lc-hero__eyebrow { margin-bottom: 28px; opacity: 0; animation: lcFadeUp .9s .3s var(--lc-ease) forwards; }
.lc-hero h1 { color: var(--lc-parchment); margin-bottom: 32px; opacity: 0; animation: lcFadeUp .9s .55s var(--lc-ease) forwards; }
.lc-hero h1 em { display: block; }
.lc-hero__sub { max-width: 540px; margin-bottom: 52px; opacity: 0; animation: lcFadeUp .9s .75s var(--lc-ease) forwards; }
.lc-hero__btns { display: flex; gap: 18px; flex-wrap: wrap; opacity: 0; animation: lcFadeUp .9s .95s var(--lc-ease) forwards; }
.lc-hero__scroll {
  position: absolute; right: 60px; bottom: 50px; z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 14px; color: var(--lc-muted);
}
.lc-hero__scroll p { font-size: .55rem; letter-spacing: .3em; text-transform: uppercase; writing-mode: vertical-lr; transform: rotate(180deg); }
.lc-hero__scroll::before {
  content: ''; display: block; width: 1px; height: 80px;
  background: linear-gradient(to bottom, transparent, var(--lc-gold));
  animation: lcLinePulse 2.2s ease-in-out infinite;
}
@keyframes lcLinePulse { 0%,100%{transform:scaleY(1);opacity:.6} 50%{transform:scaleY(.5);opacity:.2} }
@keyframes lcFadeUp { from{opacity:0;transform:translateY(36px)} to{opacity:1;transform:translateY(0)} }

/* ============================================================
   MARQUEE
   ============================================================ */
.lc-marquee { background: var(--lc-gold); padding: 16px 0; overflow: hidden; }
.lc-marquee__inner { display: flex; animation: lcMarquee 30s linear infinite; width: max-content; }
.lc-marquee__item { font-family: var(--lc-font-body); font-size: .6rem; font-weight: 500; letter-spacing: .25em; text-transform: uppercase; color: var(--lc-onyx); padding: 0 48px; white-space: nowrap; }
.lc-marquee__dot { display: inline-block; width: 4px; height: 4px; background: rgba(14,13,11,.3); border-radius: 50%; margin-right: 48px; vertical-align: middle; }
@keyframes lcMarquee { to { transform: translateX(-50%); } }

/* ============================================================
   OUR STORY
   ============================================================ */
.lc-story { padding: 160px 0; }
.lc-story__grid { display: grid; grid-template-columns: 5fr 4fr; gap: 120px; align-items: center; }
.lc-story__media { position: relative; }
.lc-story__main {
  width: 100%; aspect-ratio: 3/4;
  background: var(--lc-onyx-3) center/cover; position: relative;
}
.lc-story__accent {
  position: absolute; bottom: -50px; right: -50px; width: 55%; aspect-ratio: 1;
  background: var(--lc-onyx-3) center/cover;
  border: 6px solid var(--lc-onyx); position: absolute;
}
.lc-story__frame {
  position: absolute; top: -20px; left: -20px; right: 80px; bottom: 80px;
  border: 1px solid rgba(200,169,110,.2); pointer-events: none; z-index: -1;
}
.lc-story__content { display: flex; flex-direction: column; gap: 28px; }
.lc-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 16px; padding-top: 36px; border-top: 1px solid rgba(200,169,110,.15); }
.lc-stat__n { font-family: var(--lc-font-display); font-size: 2.6rem; font-weight: 300; color: var(--lc-gold); line-height: 1; }
.lc-stat__l { font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; color: var(--lc-muted); margin-top: 5px; }

/* ============================================================
   PHILOSOPHY
   ============================================================ */
.lc-phil { padding: 120px 0; background: var(--lc-onyx-2); }
.lc-phil__head { text-align: center; margin-bottom: 80px; }
.lc-phil__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; }
.lc-phil-card {
  background: var(--lc-onyx-3); padding: 52px 40px;
  position: relative; overflow: hidden; transition: background .4s;
}
.lc-phil-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(to right, var(--lc-gold), var(--lc-gold-2));
  transform: scaleX(0); transform-origin: left; transition: transform .5s;
}
.lc-phil-card:hover { background: var(--lc-onyx-4); }
.lc-phil-card:hover::before { transform: scaleX(1); }
.lc-phil-card__icon { width: 40px; height: 40px; margin-bottom: 28px; color: var(--lc-gold); }
.lc-phil-card__icon svg { width: 40px; height: 40px; }
.lc-phil-card h3 { font-family: var(--lc-font-display); font-size: 1.35rem; font-weight: 400; color: var(--lc-parchment); margin-bottom: 14px; }
.lc-phil-card p { font-size: .85rem; color: var(--lc-muted); line-height: 1.8; }

/* ============================================================
   COLLECTIONS
   ============================================================ */
.lc-collections { padding: 160px 0; }
.lc-collections__head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 80px; flex-wrap: wrap; gap: 32px; }
.lc-collections__grid { display: grid; grid-template-columns: 7fr 5fr; grid-template-rows: 1fr 1fr; gap: 3px; height: 780px; }
.lc-coll-card { position: relative; overflow: hidden; cursor: pointer; }
.lc-coll-card--featured { grid-row: span 2; }
.lc-coll-card__bg {
  position: absolute; inset: 0;
  background: var(--lc-onyx-3) center/cover; background-size: cover;
  transition: transform .9s var(--lc-ease);
}
.lc-coll-card:hover .lc-coll-card__bg { transform: scale(1.07); }
.lc-coll-card__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(14,13,11,.88) 0%, rgba(14,13,11,.1) 55%);
  display: flex; flex-direction: column; justify-content: flex-end; padding: 40px;
  transition: background .5s;
}
.lc-coll-card:hover .lc-coll-card__overlay {
  background: linear-gradient(to top, rgba(14,13,11,.94) 0%, rgba(14,13,11,.25) 55%);
}
.lc-coll-card__tag { font-size: .55rem; letter-spacing: .28em; text-transform: uppercase; color: var(--lc-gold); margin-bottom: 10px; }
.lc-coll-card h3 { font-family: var(--lc-font-display); font-size: 1.8rem; font-weight: 300; color: var(--lc-parchment); line-height: 1.15; }
.lc-coll-card__desc { font-size: .82rem; color: rgba(245,239,228,.65); margin-top: 10px; line-height: 1.65; max-height: 0; overflow: hidden; transition: max-height .5s, opacity .5s; opacity: 0; }
.lc-coll-card:hover .lc-coll-card__desc { max-height: 80px; opacity: 1; }
.lc-coll-card__cta { display: inline-flex; align-items: center; gap: 8px; font-size: .6rem; letter-spacing: .18em; text-transform: uppercase; color: var(--lc-gold); margin-top: 16px; max-height: 0; overflow: hidden; transition: max-height .5s .1s, opacity .5s .1s; opacity: 0; }
.lc-coll-card:hover .lc-coll-card__cta { max-height: 40px; opacity: 1; }

/* ============================================================
   SHOP BANNER
   ============================================================ */
.lc-shop-banner { padding: 110px 0; background: var(--lc-onyx-2); position: relative; overflow: hidden; }
.lc-shop-banner::before {
  content: 'LONDON CARPETS'; position: absolute; right: -20px; top: 50%; transform: translateY(-50%);
  font-family: var(--lc-font-display); font-size: 10rem; font-weight: 300;
  color: rgba(200,169,110,.03); white-space: nowrap; pointer-events: none;
}
.lc-shop-banner__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; }
.lc-shop-banner__media { position: relative; }
.lc-shop-banner__photo { width: 100%; aspect-ratio: 4/3; background: var(--lc-onyx-3) center/cover; position: relative; }
.lc-shop-banner__badge { position: absolute; bottom: -22px; left: -22px; background: var(--lc-gold); padding: 28px 32px; }
.lc-shop-banner__badge p { font-family: var(--lc-font-display); font-size: 1.1rem; font-weight: 400; color: var(--lc-onyx); line-height: 1.2; }
.lc-shop-banner__badge span { font-size: .5rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(14,13,11,.55); display: block; margin-top: 5px; }
.lc-shop-banner__content { display: flex; flex-direction: column; gap: 26px; }
.lc-shop-pills { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 4px; }
.lc-shop-pill { font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; padding: 7px 16px; border: 1px solid rgba(200,169,110,.25); color: var(--lc-muted); transition: border-color .3s, color .3s; }
.lc-shop-pill:hover { border-color: var(--lc-gold); color: var(--lc-gold); }

/* ============================================================
   PROCESS
   ============================================================ */
.lc-process { padding: 160px 0; }
.lc-process__inner { display: grid; grid-template-columns: 4fr 6fr; gap: 100px; align-items: start; }
.lc-process__sticky { position: sticky; top: 140px; }
.lc-steps { display: flex; flex-direction: column; }
.lc-step { display: grid; grid-template-columns: 72px 1fr; padding: 44px 0; border-bottom: 1px solid rgba(245,239,228,.08); transition: border-color .3s; }
.lc-step:last-child { border-bottom: none; }
.lc-step:hover { border-bottom-color: rgba(200,169,110,.25); }
.lc-step__n { font-family: var(--lc-font-display); font-size: 4.5rem; font-weight: 300; color: rgba(200,169,110,.15); line-height: 1; transition: color .4s; }
.lc-step:hover .lc-step__n { color: rgba(200,169,110,.5); }
.lc-step__content { padding-top: 8px; }
.lc-step__content h3 { font-family: var(--lc-font-display); font-size: 1.45rem; font-weight: 400; color: var(--lc-parchment); margin-bottom: 12px; }
.lc-step__content p { font-size: .87rem; color: var(--lc-muted); line-height: 1.8; }
.lc-step__content a { color: var(--lc-gold); }

/* ============================================================
   MATERIALS
   ============================================================ */
.lc-materials { padding: 160px 0; background: var(--lc-onyx-2); }
.lc-materials__head { margin-bottom: 80px; }
.lc-materials__grid-wrap { max-width: var(--lc-max-w); margin: 0 auto; padding: 0 60px; }
.lc-materials__grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 2px; }
.lc-mat-card { position: relative; aspect-ratio: 2/3; overflow: hidden; }
.lc-mat-card__bg {
  position: absolute; inset: 0;
  background: var(--lc-onyx-3) center/cover;
  transition: transform .7s, filter .7s;
  filter: brightness(.6) saturate(.7);
}
.lc-mat-card:hover .lc-mat-card__bg { transform: scale(1.1); filter: brightness(.78) saturate(.9); }
.lc-mat-card__info { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px 22px; background: linear-gradient(to top, rgba(14,13,11,.92), transparent); }
.lc-mat-card__info h4 { font-family: var(--lc-font-display); font-size: 1.1rem; font-weight: 400; color: var(--lc-parchment); }
.lc-mat-card__info p { font-size: .58rem; letter-spacing: .15em; text-transform: uppercase; color: var(--lc-gold); margin-top: 3px; }

/* ============================================================
   TESTIMONIAL
   ============================================================ */
.lc-testi { padding: 160px 0; text-align: center; }
.lc-testi__rule { width: 60px; height: 1px; background: var(--lc-gold); margin: 0 auto 52px; }
.lc-testi__quote { font-family: var(--lc-font-display); font-size: clamp(1.8rem,3vw,3rem); font-weight: 300; font-style: italic; color: var(--lc-parchment); line-height: 1.4; max-width: 880px; margin: 0 auto 36px; }
.lc-testi__attr { display: flex; flex-direction: column; align-items: center; gap: 5px; }
.lc-testi__name { font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: var(--lc-gold); }
.lc-testi__location { font-size: .75rem; color: var(--lc-muted); }

/* ============================================================
   CONTACT
   ============================================================ */
.lc-contact { padding: 160px 0; background: var(--lc-onyx-2); }
.lc-contact__grid { display: grid; grid-template-columns: 5fr 6fr; gap: 120px; align-items: start; }
.lc-contact__info { position: sticky; top: 140px; }
.lc-contact__items { display: flex; flex-direction: column; gap: 40px; margin-top: 48px; }
.lc-contact__item h5 { font-size: .58rem; letter-spacing: .25em; text-transform: uppercase; color: var(--lc-gold); margin-bottom: 8px; }
.lc-contact__item a { font-family: var(--lc-font-display); font-size: 1.3rem; font-weight: 300; color: var(--lc-parchment); transition: color .3s; display: block; }
.lc-contact__item a:hover { color: var(--lc-gold-2); }
.lc-contact__shop-link { font-family: var(--lc-font-body) !important; font-size: 1rem !important; font-weight: 300; }
.lc-contact__coverage, .lc-contact__types { font-family: var(--lc-font-display); font-size: 1rem; color: var(--lc-parchment); }
.lc-contact__types { font-size: .85rem !important; color: var(--lc-muted) !important; font-family: var(--lc-font-body) !important; }
.lc-contact__divider { width: 100%; height: 1px; background: rgba(200,169,110,.15); }

/* Contact Form */
.lc-form { display: flex; flex-direction: column; gap: 24px; }
.lc-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.lc-form__group { display: flex; flex-direction: column; gap: 8px; }
.lc-form__group label { font-size: .6rem; letter-spacing: .22em; text-transform: uppercase; color: var(--lc-gold); }
.lc-form__group input,
.lc-form__group select,
.lc-form__group textarea {
  background: rgba(245,239,228,.04); border: 1px solid rgba(245,239,228,.12);
  color: var(--lc-parchment); font-family: var(--lc-font-body); font-size: .9rem; font-weight: 300;
  padding: 16px 18px; transition: border-color .3s, background .3s;
  outline: none; resize: none; -webkit-appearance: none; appearance: none; width: 100%;
}
.lc-form__group input::placeholder,
.lc-form__group textarea::placeholder { color: rgba(245,239,228,.22); }
.lc-form__group input:focus,
.lc-form__group select:focus,
.lc-form__group textarea:focus { border-color: var(--lc-gold); background: rgba(245,239,228,.06); }
.lc-form__group select { color: var(--lc-parchment); cursor: pointer; }
.lc-form__group select option { background: var(--lc-onyx-3); color: var(--lc-parchment); }
.lc-form__group textarea { min-height: 150px; }
.lc-form__consent { display: flex; align-items: flex-start; gap: 14px; margin-top: 4px; }
.lc-form__consent input[type="checkbox"] { width: 16px; height: 16px; flex-shrink: 0; accent-color: var(--lc-gold); margin-top: 3px; cursor: pointer; }
.lc-form__consent label { font-size: .77rem; color: var(--lc-muted); line-height: 1.65; cursor: pointer; }
.lc-form__consent a { color: var(--lc-gold); text-decoration: underline; }
.lc-form__submit { text-align: right; margin-top: 8px; }
.lc-form-ok {
  display: none; padding: 28px 32px;
  background: rgba(200,169,110,.07); border: 1px solid rgba(200,169,110,.25);
  color: var(--lc-gold); font-size: .88rem; text-align: center; line-height: 1.7;
}
.lc-form-ok.lc-visible { display: block; }
.lc-field-error { border-color: rgba(220,80,80,.5) !important; }

/* ============================================================
   INNER PAGE (Privacy Policy, T&Cs)
   ============================================================ */
.lc-inner-hero {
  padding: 140px 0 64px; text-align: center;
  background: var(--lc-onyx-2); border-bottom: 1px solid rgba(200,169,110,.12);
}
.lc-inner-hero__meta { margin-top: 12px; font-size: .8rem; color: var(--lc-muted); }
.lc-inner-content { padding: 80px 0 120px; }
.lc-prose { max-width: 860px; margin: 0 auto; }
.lc-prose h2 { font-family: var(--lc-font-display); font-size: 1.6rem; font-weight: 400; color: var(--lc-parchment); margin: 48px 0 14px; }
.lc-prose h2:first-child { margin-top: 0; }
.lc-prose h3 { font-family: var(--lc-font-display); font-size: 1.15rem; font-weight: 400; color: var(--lc-parchment); margin: 32px 0 10px; }
.lc-prose p, .lc-prose li { font-size: .88rem; color: var(--lc-muted); line-height: 1.9; }
.lc-prose strong { color: var(--lc-parchment); }
.lc-prose ul { margin: 10px 0 10px 20px; display: flex; flex-direction: column; gap: 6px; }
.lc-prose a { color: var(--lc-gold); text-decoration: underline; }
.lc-legal-box { background: rgba(200,169,110,.06); border-left: 2px solid var(--lc-gold); padding: 20px 24px; margin: 0 0 40px; }
.lc-legal-box strong { color: var(--lc-parchment); display: block; margin-bottom: 8px; font-size: .85rem; }
.lc-legal-box a { color: var(--lc-gold); }
.lc-prose__rule { width: 60px; height: 1px; background: var(--lc-gold); margin: 48px 0; }

/* ============================================================
   FOOTER
   ============================================================ */
.lc-footer { background: var(--lc-onyx); border-top: 1px solid rgba(200,169,110,.1); }
.lc-footer__top { padding: 100px 0 70px; }
.lc-footer__grid { display: grid; grid-template-columns: 3fr 1.5fr 1.5fr 2fr; gap: 70px; }
.lc-footer__logo { font-family: var(--lc-font-display); font-size: 1.5rem; font-weight: 400; color: var(--lc-parchment); margin-bottom: 5px; }
.lc-footer__tagline { font-size: .5rem; letter-spacing: .28em; text-transform: uppercase; color: var(--lc-gold); margin-bottom: 20px; }
.lc-footer__brand p { font-size: .82rem; color: var(--lc-muted); max-width: 280px; line-height: 1.8; }
.lc-footer__col h6 { font-size: .58rem; letter-spacing: .25em; text-transform: uppercase; color: var(--lc-gold); margin-bottom: 22px; }
.lc-footer__col ul { list-style: none; display: flex; flex-direction: column; gap: 13px; }
.lc-footer__col ul li a { font-size: .82rem; color: var(--lc-muted); transition: color .3s; }
.lc-footer__col ul li a:hover { color: var(--lc-parchment); }
.lc-footer__newsletter h6 { font-size: .58rem; letter-spacing: .25em; text-transform: uppercase; color: var(--lc-gold); margin-bottom: 22px; }
.lc-footer__newsletter p { font-size: .82rem; color: var(--lc-muted); margin-bottom: 20px; line-height: 1.7; }
.lc-newsletter { display: flex; }
.lc-newsletter input {
  flex: 1; background: rgba(245,239,228,.05); border: 1px solid rgba(245,239,228,.12);
  border-right: none; color: var(--lc-parchment); font-family: var(--lc-font-body);
  font-size: .82rem; padding: 13px 16px; outline: none; transition: border-color .3s;
}
.lc-newsletter input:focus { border-color: var(--lc-gold); }
.lc-newsletter input::placeholder { color: rgba(245,239,228,.22); }
.lc-newsletter button {
  background: var(--lc-gold); color: var(--lc-onyx); border: none;
  font-family: var(--lc-font-body); font-size: .6rem; letter-spacing: .18em;
  text-transform: uppercase; padding: 13px 20px; cursor: pointer; transition: background .3s;
}
.lc-newsletter button:hover { background: var(--lc-gold-2); }
.lc-footer__bottom { padding: 28px 0; border-top: 1px solid rgba(245,239,228,.06); }
.lc-footer__bottom-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.lc-footer__legal { font-size: .62rem; color: rgba(245,239,228,.2); line-height: 1.7; max-width: 700px; }
.lc-footer__legal a { color: rgba(245,239,228,.3); transition: color .3s; }
.lc-footer__legal a:hover { color: var(--lc-gold); }
.lc-footer__links { display: flex; gap: 24px; flex-wrap: wrap; }
.lc-footer__links a { font-size: .65rem; color: rgba(245,239,228,.3); letter-spacing: .05em; transition: color .3s; }
.lc-footer__links a:hover { color: var(--lc-gold); }

/* Page content (for Elementor-edited pages) */
.lc-page-content { min-height: 60vh; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.lc-rv {
  opacity: 0; transform: translateY(48px);
  transition: opacity .9s var(--lc-ease-out), transform .9s var(--lc-ease-out);
}
.lc-rv.lc-vis { opacity: 1; transform: none; }
.lc-d0 { transition-delay: 0s; }
.lc-d1 { transition-delay: .15s; }
.lc-d2 { transition-delay: .3s; }
.lc-d3 { transition-delay: .45s; }


/* ============================================================
   RESPONSIVE — Full mobile-first breakpoints
   Tested targets: 320px, 375px, 390px, 430px, 768px, 1024px, 1280px+
   ============================================================ */

/* ── TABLET: 1100px and below ── */
@media (max-width: 1100px) {
  .lc-wrap { padding: 0 40px; }
  .lc-nav { padding: 24px 40px; }
  .lc-nav.lc-nav--scrolled { padding: 16px 40px; }

  /* Story */
  .lc-story__grid { grid-template-columns: 1fr; gap: 60px; }
  .lc-story__accent { bottom: -30px; right: -30px; width: 45%; }
  .lc-story__frame { right: 50px; bottom: 50px; }

  /* Philosophy */
  .lc-phil__grid { grid-template-columns: 1fr 1fr; gap: 2px; }

  /* Shop banner */
  .lc-shop-banner__inner { grid-template-columns: 1fr; gap: 60px; }
  .lc-shop-banner__badge { bottom: -18px; left: -18px; }

  /* Process */
  .lc-process__inner { grid-template-columns: 1fr; gap: 60px; }
  .lc-process__sticky { position: static; }

  /* Materials */
  .lc-materials__grid { grid-template-columns: repeat(3, 1fr); }
  .lc-materials__grid-wrap { padding: 0 40px; }

  /* Contact */
  .lc-contact__grid { grid-template-columns: 1fr; gap: 60px; }
  .lc-contact__info { position: static; }

  /* Footer */
  .lc-footer__grid { grid-template-columns: 1fr 1fr; gap: 48px; }
  .lc-footer__top { padding: 80px 0 60px; }
}

/* ── MOBILE LARGE: 768px and below ── */
@media (max-width: 768px) {
  /* Base */
  html { font-size: 15px; }
  .lc-wrap { padding: 0 20px; }
  body { cursor: auto; }
  .lc-cursor, .lc-cursor-ring { display: none; }

  /* Section padding */
  .lc-section { padding: 80px 0; }
  .lc-story { padding: 80px 0; }
  .lc-phil { padding: 70px 0; }
  .lc-collections { padding: 80px 0; }
  .lc-shop-banner { padding: 70px 0; }
  .lc-process { padding: 80px 0; }
  .lc-materials { padding: 80px 0; }
  .lc-testi { padding: 80px 0; }
  .lc-contact { padding: 80px 0; }

  /* Typography */
  .lc-display--xl { font-size: clamp(2.6rem, 9vw, 3.8rem); line-height: 1.08; }
  .lc-display--md { font-size: clamp(1.7rem, 6vw, 2.4rem); line-height: 1.15; }
  .lc-body-lg { font-size: .95rem; }

  /* Navigation */
  .lc-nav { padding: 18px 20px; }
  .lc-nav.lc-nav--scrolled { padding: 14px 20px; }
  .lc-nav__links, .lc-nav__cta { display: none; }
  /* Email button hidden on mobile - shown in mobile nav instead */
  .lc-hamburger { display: flex; }
  .lc-mob-nav a { font-size: 1.7rem; }
  .lc-mob-nav__links { gap: 22px; }
  .lc-mob-nav__contact { padding-top: 28px; max-width: 100%; }
  .lc-mob-nav__email { font-size: .9rem !important; padding: 16px 24px; gap: 10px; }
  .lc-mob-nav__contact-label { font-size: .52rem; }

  /* Hero */
  .lc-hero { min-height: 100svh; min-height: 100vh; }
  .lc-hero__content { padding: 0 20px 80px; }
  .lc-hero h1 { margin-bottom: 20px; }
  .lc-hero__sub { font-size: .9rem; margin-bottom: 36px; max-width: 100%; }
  .lc-hero__btns { flex-direction: column; gap: 12px; width: 100%; }
  .lc-hero__btns .lc-btn { width: 100%; justify-content: center; padding: 16px 24px; font-size: .68rem; }
  .lc-hero__scroll { display: none; }

  /* Marquee */
  .lc-marquee__item { padding: 0 28px; font-size: .58rem; }
  .lc-marquee__dot { margin-right: 28px; }

  /* Story */
  .lc-story__grid { grid-template-columns: 1fr; gap: 56px; }
  .lc-story__media { margin-bottom: 20px; }
  .lc-story__main { aspect-ratio: 4/3; }
  .lc-story__accent { display: none; }
  .lc-story__frame { display: none; }
  .lc-story__content { gap: 20px; }
  .lc-stats { grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 12px; padding-top: 28px; }
  .lc-stat__n { font-size: 2rem; }
  .lc-stat__l { font-size: .58rem; }

  /* Philosophy */
  .lc-phil__grid { grid-template-columns: 1fr; gap: 2px; }
  .lc-phil-card { padding: 36px 28px; }
  .lc-phil__head { margin-bottom: 48px; }

  /* Collections */
  .lc-collections__head { flex-direction: column; align-items: flex-start; gap: 24px; margin-bottom: 40px; }
  .lc-collections__head > div:last-child { text-align: left !important; }
  .lc-collections__grid { grid-template-columns: 1fr; grid-template-rows: auto; height: auto; gap: 3px; }
  .lc-coll-card--featured { grid-row: span 1; }
  .lc-coll-card { aspect-ratio: 4/3; }
  .lc-coll-card__overlay { padding: 24px; }
  .lc-coll-card h3 { font-size: 1.4rem; }
  /* Always show desc on mobile */
  .lc-coll-card__desc { max-height: none !important; opacity: 1 !important; margin-top: 8px; }
  .lc-coll-card__cta { max-height: none !important; opacity: 1 !important; }

  /* Shop banner */
  .lc-shop-banner { padding: 60px 0; }
  .lc-shop-banner::before { display: none; }
  .lc-shop-banner__inner { grid-template-columns: 1fr; gap: 48px; }
  .lc-shop-banner__photo { aspect-ratio: 3/2; }
  .lc-shop-banner__badge { bottom: -16px; left: 16px; padding: 18px 22px; }
  .lc-shop-banner__badge p { font-size: .9rem; }
  .lc-shop-banner__content { gap: 20px; }
  .lc-shop-pills { gap: 8px; }
  .lc-shop-pill { font-size: .58rem; padding: 6px 12px; }
  .lc-shop-banner__content > div:last-child { flex-direction: column; }
  .lc-shop-banner__content > div:last-child .lc-btn { width: 100%; justify-content: center; }

  /* Process */
  .lc-process__inner { grid-template-columns: 1fr; gap: 48px; }
  .lc-process__sticky { position: static; margin-bottom: 0; }
  .lc-process__sticky .lc-btn { display: none; }
  .lc-step { grid-template-columns: 52px 1fr; padding: 32px 0; }
  .lc-step__n { font-size: 3.2rem; }
  .lc-step__content h3 { font-size: 1.2rem; margin-bottom: 8px; }
  .lc-step__content p { font-size: .85rem; }

  /* Materials */
  .lc-materials__grid-wrap { padding: 0 20px; }
  .lc-materials__grid { grid-template-columns: 1fr 1fr; gap: 3px; }
  .lc-mat-card { aspect-ratio: 3/4; }
  .lc-mat-card__info h4 { font-size: .95rem; }
  .lc-mat-card__info p { font-size: .55rem; }
  .lc-materials__head { margin-bottom: 48px; }

  /* Testimonial */
  .lc-testi__quote { font-size: clamp(1.3rem, 5vw, 1.8rem); margin-bottom: 24px; }
  .lc-testi__rule { margin-bottom: 36px; }

  /* Contact */
  .lc-contact__grid { grid-template-columns: 1fr; gap: 48px; }
  .lc-contact__info { position: static; }
  .lc-contact__items { gap: 28px; margin-top: 32px; }
  .lc-contact__item a { font-size: 1rem; }
  .lc-contact__item h5 { font-size: .55rem; }

  /* Form */
  .lc-form__row { grid-template-columns: 1fr; gap: 16px; }
  .lc-form { gap: 18px; }
  .lc-form__group input,
  .lc-form__group select,
  .lc-form__group textarea { padding: 14px 16px; font-size: .88rem; }
  .lc-form__group label { font-size: .58rem; }
  .lc-form__consent label { font-size: .74rem; }
  .lc-form__submit { text-align: left; }
  .lc-form__submit .lc-btn { width: 100%; justify-content: center; }
  .lc-form__group textarea { min-height: 120px; }

  /* Cookie banner */
  .lc-cookie-banner { padding: 16px 20px; flex-direction: column; gap: 16px; }
  .lc-cookie-banner__text p { font-size: .78rem; }
  .lc-cookie-banner__actions { width: 100%; flex-direction: column; gap: 8px; }
  .lc-cookie-btn { width: 100%; text-align: center; }
  .lc-cookie-modal__header { padding: 28px 24px 20px; }
  .lc-cookie-modal__body { padding: 20px 24px; }
  .lc-cookie-modal__footer { padding: 16px 24px 28px; flex-direction: column; gap: 8px; }
  .lc-cookie-modal__footer .lc-cookie-btn { width: 100%; text-align: center; }

  /* Footer */
  .lc-footer__top { padding: 60px 0 48px; }
  .lc-footer__grid { grid-template-columns: 1fr; gap: 40px; }
  .lc-footer__brand { margin-bottom: 8px; }
  .lc-footer__brand p { max-width: 100%; }
  .lc-footer__bottom-inner { flex-direction: column; align-items: flex-start; gap: 20px; }
  .lc-footer__links { flex-wrap: wrap; gap: 16px; }
  .lc-footer__legal { font-size: .6rem; }
  .lc-newsletter { flex-direction: column; gap: 8px; }
  .lc-newsletter input { border-right: 1px solid rgba(245,239,228,.12); width: 100%; }
  .lc-newsletter button { width: 100%; padding: 14px 20px; }

  /* Inner pages (Privacy, T&Cs) */
  .lc-inner-hero { padding: 120px 0 56px; }
  .lc-inner-content { padding: 56px 0 80px; }
  .lc-prose h2 { font-size: 1.3rem; margin-top: 36px; }
  .lc-prose p, .lc-prose li { font-size: .85rem; }
  .lc-legal-box { padding: 16px 18px; }

  /* Buttons */
  .lc-btn { padding: 15px 28px; font-size: .67rem; }
  .lc-btn--sm { padding: 12px 22px; font-size: .63rem; }

  /* Image placeholders */
  .lc-image-placeholder p { font-size: .68rem; }
}

/* ── MOBILE SMALL: 480px and below ── */
@media (max-width: 480px) {
  html { font-size: 14px; }
  .lc-mob-nav a { font-size: 1.5rem; }
  .lc-mob-nav__links { gap: 18px; }
  .lc-mob-nav__email { font-size: .82rem !important; padding: 14px 20px; }
  .lc-wrap { padding: 0 16px; }
  .lc-nav { padding: 16px; }
  .lc-nav.lc-nav--scrolled { padding: 12px 16px; }
  .lc-nav__logo { font-size: 1.2rem; }

  /* Hero */
  .lc-hero__content { padding: 0 16px 70px; }
  .lc-display--xl { font-size: clamp(2.2rem, 10vw, 3rem); }
  .lc-hero__btns .lc-btn { font-size: .64rem; padding: 15px 20px; }

  /* Stats */
  .lc-stats { grid-template-columns: 1fr 1fr; gap: 16px; }
  .lc-stat__n { font-size: 1.7rem; }

  /* Philosophy */
  .lc-phil-card { padding: 28px 20px; }
  .lc-phil-card h3 { font-size: 1.15rem; }

  /* Collections */
  .lc-coll-card { aspect-ratio: 1/1; }
  .lc-coll-card h3 { font-size: 1.2rem; }

  /* Materials */
  .lc-materials__grid-wrap { padding: 0 16px; }
  .lc-materials__grid { grid-template-columns: 1fr 1fr; gap: 2px; }
  .lc-mat-card { aspect-ratio: 1/1; }

  /* Process */
  .lc-step { grid-template-columns: 44px 1fr; }
  .lc-step__n { font-size: 2.6rem; }

  /* Testimonial */
  .lc-testi__quote { font-size: 1.3rem; }

  /* Contact */
  .lc-contact__item a { font-size: .9rem; }

  /* Footer */
  .lc-footer__grid { gap: 32px; }
  .lc-footer__links { gap: 12px; }
  .lc-footer__links a { font-size: .6rem; }

  /* Inner pages */
  .lc-inner-hero { padding: 110px 0 48px; }
  .lc-prose h2 { font-size: 1.2rem; }
}

/* ── TINY: 360px and below (older Android) ── */
@media (max-width: 360px) {
  html { font-size: 13px; }
  .lc-wrap { padding: 0 14px; }
  .lc-display--xl { font-size: 2rem; }
  .lc-display--md { font-size: 1.55rem; }
  .lc-hero__content { padding: 0 14px 60px; }
  .lc-coll-card { aspect-ratio: 3/4; }
  .lc-materials__grid { grid-template-columns: 1fr; }
  .lc-mat-card { aspect-ratio: 3/2; }
  .lc-footer__links { flex-direction: column; gap: 10px; }
}

/* ── TOUCH: hover states off on touch devices ── */
@media (hover: none) and (pointer: coarse) {
  .lc-cursor, .lc-cursor-ring { display: none !important; }
  body { cursor: auto !important; }
  /* Always show collection overlays on touch */
  .lc-coll-card__overlay {
    background: linear-gradient(to top, rgba(14,13,11,.88) 0%, rgba(14,13,11,.2) 60%) !important;
  }
  .lc-coll-card__desc { max-height: none !important; opacity: 1 !important; }
  .lc-coll-card__cta  { max-height: none !important; opacity: 1 !important; }
  /* Always show mat card info */
  .lc-mat-card__bg { filter: brightness(.7) saturate(.8) !important; }
  /* Phil card top bar always visible */
  .lc-phil-card::before { transform: scaleX(1) !important; }
}

/* ── LANDSCAPE MOBILE ── */
@media (max-width: 768px) and (orientation: landscape) {
  .lc-hero { min-height: 100vw; }
  .lc-hero__content { padding-bottom: 60px; }
  .lc-hero__btns { flex-direction: row; }
  .lc-hero__btns .lc-btn { width: auto; }
}

/* ── HIGH DPI / RETINA ── */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .lc-hero__bg, .lc-story__main, .lc-story__accent,
  .lc-coll-card__bg, .lc-shop-banner__photo,
  .lc-mat-card__bg { background-size: cover; image-rendering: -webkit-optimize-contrast; }
}

/* ── REDUCED MOTION: respect accessibility preference ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .lc-rv { opacity: 1 !important; transform: none !important; }
  .lc-hero-bg { animation: none !important; }
  .lc-marquee__inner { animation-play-state: paused !important; }
}
