/* ========================================
   LED WALL PAGE — True Apple.com Design
   Grid layout · Cinematic sections · Inter font
   Blue accent #0071e3 · Apple color system
   ======================================== */

/* ── CSS Variables ── */
:root {
    --lw-white: #ffffff;
    --lw-black: #000000;
    --lw-bg: #ffffff;
    --lw-bg-alt: #f5f5f7;
    --lw-bg-dark: #000000;
    --lw-text: #1d1d1f;
    --lw-text-sec: #6e6e73;
    --lw-text-dim: #86868b;
    --lw-blue: #0071e3;
    --lw-blue-hover: #0077ed;
    --lw-border: #d2d2d7;
    --lw-card-bg: #fbfbfd;
    --lw-card-border: #e8e8ed;
    --lw-radius: 20px;
    --lw-radius-sm: 14px;
    --lw-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* ========================================
   PROMO BANNER
   ======================================== */
.lw-promo {
    background: var(--lw-bg-alt);
    color: var(--lw-text);
    text-align: center;
    font-size: 0.87rem;
    font-family: var(--lw-font);
    padding: 14px 24px;
    line-height: 1.5;
    border-bottom: 1px solid var(--lw-card-border);
    margin-top: 60px;
}
.lw-promo a {
    color: var(--lw-blue);
    text-decoration: none;
    font-weight: 500;
}
.lw-promo a:hover { text-decoration: underline; }

/* ========================================
   HERO — Dark cinematic
   ======================================== */
.lw-hero {
    background: var(--lw-bg-dark);
    text-align: center;
    padding: 100px 24px 40px;
    overflow: hidden;
    position: relative;
    min-height: 85vh;
    display: flex;
    align-items: center;
    justify-content: center;
}
.lw-hero .glow-orbs {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 1;
}
.lw-hero::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 200px;
    background: linear-gradient(to top, #000, transparent);
    pointer-events: none;
    z-index: 2;
}
.lw-hero-inner {
    position: relative;
    z-index: 3;
    max-width: 900px;
    margin: 0 auto;
}
.lw-hero-eyebrow {
    font-size: clamp(0.85rem, 1.5vw, 1rem);
    font-weight: 600;
    color: var(--lw-blue);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 12px;
    display: block;
    font-family: var(--lw-font);
}
.lw-hero-title {
    font-size: clamp(3.2rem, 9vw, 6rem);
    font-weight: 800;
    color: #f5f5f7;
    letter-spacing: -0.04em;
    line-height: 1.02;
    margin-bottom: 20px;
    font-family: var(--lw-font);
}
.lw-hero-subtitle {
    font-size: clamp(1rem, 2vw, 1.4rem);
    font-weight: 400;
    color: #a1a1a6;
    line-height: 1.4;
    margin-bottom: 24px;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
    font-family: var(--lw-font);
}
.lw-hero-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 28px;
    margin-bottom: 56px;
}
.lw-hero-img {
    max-width: 760px;
    margin: 0 auto;
    padding-bottom: 40px;
}
.lw-hero-img img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 16px;
    filter: drop-shadow(0 30px 60px rgba(0,0,0,0.4));
}

/* ── Global blue link ── */
.lw-link-blue {
    color: #2997ff;
    font-size: 1.05rem;
    font-weight: 400;
    text-decoration: none;
    transition: color 0.2s;
    cursor: pointer;
    font-family: var(--lw-font);
}
.lw-link-blue:hover {
    color: #4db3ff;
    text-decoration: underline;
}
.lw-link--lg { font-size: 1.15rem; }

/* ========================================
   SECTION TITLES (Apple typography)
   ======================================== */
.lw-sec-title {
    font-size: clamp(2rem, 5vw, 3.2rem);
    font-weight: 700;
    font-family: var(--lw-font);
    color: var(--lw-text);
    letter-spacing: -0.035em;
    line-height: 1.08;
    margin-bottom: 12px;
}
.lw-sec-sub {
    font-size: clamp(0.9rem, 1.5vw, 1.1rem);
    font-family: var(--lw-font);
    color: var(--lw-text-sec);
    line-height: 1.5;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}

/* ========================================
   PERFECT PIXEL PITCH — Apple feature section
   ======================================== */
.lw-pitch {
    padding: 120px 24px 100px;
    background: #f5f5f7;
    text-align: center;
    overflow: hidden;
}
.lw-pitch-inner {
    max-width: 680px;
    margin: 0 auto 64px;
}
.lw-pitch-eyebrow {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--lw-blue);
    margin-bottom: 12px;
    display: block;
    font-family: var(--lw-font);
}
.lw-pitch-title {
    font-size: clamp(2rem, 5vw, 3.2rem);
    font-weight: 700;
    color: var(--lw-text);
    letter-spacing: -0.035em;
    line-height: 1.08;
    margin-bottom: 20px;
    font-family: var(--lw-font);
}
.lw-pitch-desc {
    font-size: clamp(0.9rem, 1.5vw, 1.1rem);
    color: var(--lw-text-sec);
    line-height: 1.6;
    font-family: var(--lw-font);
}

/* Pitch cards grid */
.lw-pitch-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 24px;
}
.lw-pitch-card {
    background: var(--lw-white);
    border-radius: 18px;
    padding: 36px 28px 32px;
    text-align: left;
    border: none;
    box-shadow: 0 0 0 1px rgba(0,0,0,0.04), 0 4px 16px rgba(0,0,0,0.04);
    position: relative;
    overflow: hidden;
    transition: transform 0.5s cubic-bezier(.25,.46,.45,.94),
                box-shadow 0.5s cubic-bezier(.25,.46,.45,.94);
}
.lw-pitch-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 0 0 1px rgba(0,0,0,0.04), 0 12px 40px rgba(0,0,0,0.1);
}

/* ── Animated SVG icons ── */
.lw-pitch-anim {
    width: 52px;
    height: 52px;
    margin-bottom: 24px;
}
.lw-pitch-anim svg {
    width: 100%;
    height: 100%;
}

/* Ultra Fine — pixel grid animation */
.lw-pitch-anim--pixels .px {
    fill: #1d1d1f;
    opacity: 0;
    animation: pxFade 2.4s ease-in-out infinite;
}
.lw-pitch-anim--pixels .px1 { animation-delay: 0s; }
.lw-pitch-anim--pixels .px2 { animation-delay: 0.1s; }
.lw-pitch-anim--pixels .px3 { animation-delay: 0.2s; }
.lw-pitch-anim--pixels .px4 { animation-delay: 0.3s; }
.lw-pitch-anim--pixels .px5 { animation-delay: 0.15s; }
.lw-pitch-anim--pixels .px6 { animation-delay: 0.25s; }
.lw-pitch-anim--pixels .px7 { animation-delay: 0.35s; }
.lw-pitch-anim--pixels .px8 { animation-delay: 0.2s; }
.lw-pitch-anim--pixels .px9 { animation-delay: 0.05s; }
@keyframes pxFade {
    0%, 100% { opacity: 0.15; }
    50% { opacity: 1; }
}

/* Fine — screen glow animation */
.lw-pitch-anim--screen .scr-body { stroke: #1d1d1f; fill: none; }
.lw-pitch-anim--screen .scr-stand { stroke: #1d1d1f; }
.lw-pitch-anim--screen .scr-base  { stroke: #1d1d1f; }
.lw-pitch-anim--screen .scr-glow {
    fill: #0071e3;
    opacity: 0.12;
    animation: scrPulse 3s ease-in-out infinite;
}
@keyframes scrPulse {
    0%, 100% { opacity: 0.08; }
    50% { opacity: 0.25; }
}

/* Standard — venue arc pulse */
.lw-pitch-anim--venue .ven-arc  { stroke: #1d1d1f; }
.lw-pitch-anim--venue .ven-l    { stroke: #1d1d1f; }
.lw-pitch-anim--venue .ven-r    { stroke: #1d1d1f; }
.lw-pitch-anim--venue .ven-floor { stroke: #1d1d1f; }
.lw-pitch-anim--venue .ven-dot {
    fill: #1d1d1f;
    animation: venBeat 2s ease-in-out infinite;
}
@keyframes venBeat {
    0%, 100% { r: 3; opacity: 0.4; }
    50% { r: 5; opacity: 1; }
}

/* Large — highway dashes animation */
.lw-pitch-anim--highway .hw-road { stroke: #1d1d1f; fill: none; }
.lw-pitch-anim--highway .hw-dash {
    stroke: #1d1d1f;
    animation: hwMove 1.5s linear infinite;
}
.lw-pitch-anim--highway .hw-d1 { animation-delay: 0s; }
.lw-pitch-anim--highway .hw-d2 { animation-delay: 0.5s; }
.lw-pitch-anim--highway .hw-d3 { animation-delay: 1s; }
@keyframes hwMove {
    0% { opacity: 0; transform: translateY(-6px); }
    30% { opacity: 1; }
    70% { opacity: 1; }
    100% { opacity: 0; transform: translateY(6px); }
}

/* ── Card hover — icons speed up ── */
.lw-pitch-card:hover .lw-pitch-anim--pixels .px  { animation-duration: 1.2s; }
.lw-pitch-card:hover .lw-pitch-anim--screen .scr-glow { animation-duration: 1.2s; }
.lw-pitch-card:hover .lw-pitch-anim--venue .ven-dot   { animation-duration: 0.8s; }
.lw-pitch-card:hover .lw-pitch-anim--highway .hw-dash  { animation-duration: 0.8s; }

.lw-pitch-card h3 {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--lw-text);
    letter-spacing: -0.025em;
    margin-bottom: 4px;
    font-family: var(--lw-font);
}
.lw-pitch-range {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--lw-text-dim);
    margin-bottom: 14px;
    font-family: var(--lw-font);
}
.lw-pitch-detail {
    font-size: 0.86rem;
    color: var(--lw-text-sec);
    line-height: 1.6;
    margin-bottom: 24px;
    font-family: var(--lw-font);
}
/* Dot meter — resolution indicator */
.lw-pitch-meter {
    display: flex;
    gap: 5px;
    margin-bottom: 8px;
}
.lw-pitch-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #d2d2d7;
    transition: background 0.4s ease;
}
.lw-pitch-dot.active {
    background: #1d1d1f;
}
.lw-pitch-label {
    font-size: 0.66rem;
    font-weight: 500;
    color: var(--lw-text-dim);
    letter-spacing: 0.02em;
    font-family: var(--lw-font);
}

/* ========================================
   LINE-UP SECTIONS
   ======================================== */
.lw-lineup {
    padding: 100px 24px 80px;
    background: var(--lw-bg);
}
.lw-lineup--dark {
    background: var(--lw-bg-dark);
}
.lw-lineup-head {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 56px;
}
.lw-lineup--dark .lw-sec-title { color: #f5f5f7; }
.lw-lineup--dark .lw-sec-sub { color: #a1a1a6; }
.lw-lineup-foot {
    text-align: center;
    padding-top: 40px;
}

/* ========================================
   PRODUCT SLIDER — Apple horizontal scroll
   ======================================== */
.lw-grid {
    display: flex;
    gap: 20px;
    max-width: 100%;
    margin: 0 auto;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    padding: 0 max(24px, calc((100vw - 1080px) / 2)) 20px;
    scrollbar-width: none;
}
.lw-grid::-webkit-scrollbar { display: none; }
.lw-grid .lw-card {
    flex: 0 0 340px;
    min-width: 340px;
    scroll-snap-align: start;
}

/* Featured card is same width in slider */
.lw-card--featured {
    flex: 0 0 340px !important;
    min-width: 340px !important;
}

/* ========================================
   PRODUCT CARD — Apple style
   ======================================== */
.lw-card {
    background: var(--lw-white);
    border: 1px solid var(--lw-card-border);
    border-radius: var(--lw-radius);
    padding: 0;
    text-align: center;
    position: relative;
    overflow: hidden;
    transition: transform 0.45s cubic-bezier(.25,.46,.45,.94),
                box-shadow 0.45s cubic-bezier(.25,.46,.45,.94);
    display: flex;
    flex-direction: column;
}
.lw-lineup--dark .lw-card {
    background: #1d1d1f;
    border-color: #2d2d2d;
}
.lw-card:hover {
    transform: translateY(-8px) scale(1.01);
    box-shadow: 0 20px 60px rgba(0,0,0,0.1);
}
.lw-lineup--dark .lw-card:hover {
    box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}

/* Badge / Tag */
.lw-tag {
    position: absolute;
    top: 18px;
    left: 18px;
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 5px 14px;
    border-radius: 980px;
    font-family: var(--lw-font);
    z-index: 2;
    backdrop-filter: blur(12px);
}
.lw-tag--blue   { background: rgba(0,113,227,0.12); color: #0071e3; }
.lw-tag--orange { background: rgba(255,159,10,0.12); color: #e65100; }
.lw-tag--green  { background: rgba(48,209,88,0.12); color: #2e7d32; }
.lw-tag--gray   { background: rgba(110,110,115,0.1); color: #6e6e73; }

/* Card image */
.lw-card-img {
    padding: 32px 24px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 220px;
    background: linear-gradient(180deg, rgba(0,0,0,0.01) 0%, transparent 100%);
}
.lw-card--featured .lw-card-img {
    min-height: 280px;
}
.lw-card-img img {
    max-width: 85%;
    max-height: 200px;
    object-fit: contain;
    transition: transform 0.6s cubic-bezier(.25,.46,.45,.94);
    filter: drop-shadow(0 8px 24px rgba(0,0,0,0.08));
}
.lw-card--featured .lw-card-img img {
    max-height: 260px;
}
.lw-card:hover .lw-card-img img {
    transform: scale(1.06);
}
.lw-lineup--dark .lw-card-img {
    background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, transparent 100%);
}
.lw-lineup--dark .lw-card-img img {
    filter: drop-shadow(0 8px 24px rgba(0,0,0,0.3));
}

/* Card body */
.lw-card-body {
    padding: 20px 28px 30px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.lw-card-name {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--lw-text);
    letter-spacing: -0.025em;
    margin-bottom: 6px;
    font-family: var(--lw-font);
}
.lw-lineup--dark .lw-card-name { color: #f5f5f7; }
.lw-card-desc {
    font-size: 0.85rem;
    color: var(--lw-text-sec);
    line-height: 1.5;
    margin-bottom: 14px;
    flex: 1;
    font-family: var(--lw-font);
}
.lw-lineup--dark .lw-card-desc { color: #a1a1a6; }
.lw-card-specs {
    font-size: 0.72rem;
    color: var(--lw-text-dim);
    letter-spacing: 0.03em;
    margin-bottom: 16px;
    font-family: var(--lw-font);
    padding: 8px 0;
    border-top: 1px solid var(--lw-card-border);
}
.lw-lineup--dark .lw-card-specs {
    color: #6e6e73;
    border-top-color: #2d2d2d;
}
.lw-card-price {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--lw-text);
    margin-bottom: 2px;
    font-family: var(--lw-font);
}
.lw-lineup--dark .lw-card-price { color: #f5f5f7; }
.lw-card-price span {
    font-weight: 400;
    font-size: 0.82rem;
    color: var(--lw-text-sec);
}
.lw-lineup--dark .lw-card-price span { color: #a1a1a6; }
.lw-card-emi {
    font-size: 0.76rem;
    color: var(--lw-text-dim);
    margin-bottom: 20px;
    font-family: var(--lw-font);
}
.lw-lineup--dark .lw-card-emi { color: #6e6e73; }
.lw-card-links {
    display: flex;
    justify-content: center;
    gap: 20px;
    padding-top: 12px;
    border-top: 1px solid var(--lw-card-border);
}
.lw-lineup--dark .lw-card-links { border-top-color: #2d2d2d; }
.lw-card-links .lw-link-blue {
    font-size: 0.9rem;
    color: var(--lw-blue);
}
.lw-lineup--dark .lw-card-links .lw-link-blue { color: #2997ff; }

/* ========================================
   COMPARE TABLE — Apple-style
   ======================================== */
/* ========================================
   THE INDOOR COLLECTION
   ======================================== */
.lw-collection {
    padding: 120px 24px 100px;
    background: #000;
}
.lw-collection-head {
    text-align: center;
    margin-bottom: 80px;
}
.lw-col-eyebrow {
    font-size: 1.1rem;
    font-weight: 600;
    color: #86868b;
    letter-spacing: -0.01em;
    margin-bottom: 12px;
    font-family: var(--lw-font);
}
.lw-collection .lw-sec-title {
    color: #f5f5f7;
}
/* Series block */
.lw-series {
    max-width: 1120px;
    margin: 0 auto 80px;
}
.lw-series:last-child { margin-bottom: 0; }
.lw-series-head {
    margin-bottom: 40px;
    padding-left: 4px;
}
.lw-series-title {
    font-size: 2rem;
    font-weight: 700;
    color: #f5f5f7;
    letter-spacing: -0.025em;
    font-family: var(--lw-font);
    margin-bottom: 8px;
}
.lw-series-title span {
    font-weight: 400;
    color: #86868b;
}
.lw-series-tag {
    font-size: 1.1rem;
    font-weight: 500;
    color: #a1a1a6;
    font-family: var(--lw-font);
    margin-bottom: 6px;
}
.lw-series-desc {
    font-size: 0.92rem;
    color: #6e6e73;
    line-height: 1.5;
    max-width: 560px;
    font-family: var(--lw-font);
}
/* Product cards grid */
.lw-series-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.lw-prod-card {
    background: #1d1d1f;
    border-radius: 20px;
    padding: 36px 28px 32px;
    display: flex;
    flex-direction: column;
    transition: transform 0.4s cubic-bezier(.25,.46,.45,.94),
                box-shadow 0.4s cubic-bezier(.25,.46,.45,.94);
}
.lw-prod-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.lw-prod-label {
    font-size: 0.78rem;
    font-weight: 600;
    color: #86868b;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 8px;
    font-family: var(--lw-font);
}
.lw-prod-name {
    font-size: 1.5rem;
    font-weight: 700;
    color: #f5f5f7;
    letter-spacing: -0.02em;
    margin-bottom: 12px;
    font-family: var(--lw-font);
}
.lw-prod-dim {
    font-size: 0.88rem;
    font-weight: 500;
    color: #a1a1a6;
    margin-bottom: 14px;
    font-family: var(--lw-font);
}
.lw-prod-sqft {
    display: inline-block;
    background: rgba(255,255,255,0.08);
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 0.76rem;
    color: #86868b;
    margin-left: 6px;
}
.lw-prod-exp {
    font-size: 0.84rem;
    color: #6e6e73;
    line-height: 1.55;
    font-family: var(--lw-font);
    flex: 1;
}
.lw-prod-price {
    font-size: 1.15rem;
    font-weight: 700;
    color: #f5f5f7;
    font-family: var(--lw-font);
    margin-top: 16px;
    margin-bottom: 14px;
    letter-spacing: -0.01em;
}
.lw-prod-price span {
    font-size: 0.78rem;
    font-weight: 500;
    color: #86868b;
}
.lw-prod-price .lw-gst {
    font-size: 0.68rem;
    font-weight: 400;
    color: #86868b;
    margin-left: 4px;
}
.lw-prod-links {
    display: flex;
    gap: 20px;
    padding-top: 14px;
    border-top: 1px solid rgba(255,255,255,0.08);
}
.lw-prod-links .lw-link-blue {
    font-size: 0.82rem;
}
/* 2-column grid variant for Landmark outdoor */
.lw-series-grid--2col {
    grid-template-columns: repeat(2, 1fr);
}
/* ========================================
   OUTDOOR COLLECTION — White / Apple-style
   ======================================== */
.lw-collection--outdoor,
.lw-collection--indoor {
    background: #f5f5f7;
}
.lw-collection--outdoor .lw-col-eyebrow,
.lw-collection--indoor .lw-col-eyebrow {
    color: #6e6e73;
}
.lw-collection--outdoor .lw-sec-title,
.lw-collection--indoor .lw-sec-title {
    color: #1d1d1f;
}
.lw-collection--outdoor .lw-series-title,
.lw-collection--indoor .lw-series-title {
    color: #1d1d1f;
}
.lw-collection--outdoor .lw-series-tag,
.lw-collection--indoor .lw-series-tag {
    color: #6e6e73;
}
.lw-collection--outdoor .lw-series-desc,
.lw-collection--indoor .lw-series-desc {
    color: #86868b;
}
.lw-collection--indoor .lw-sec-sub {
    color: #86868b;
}
/* Horizontal scroll track */
.lw-scroll-track {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    margin: 0 -24px;
    padding: 0 24px 20px;
}
.lw-scroll-track::-webkit-scrollbar { display: none; }
.lw-scroll-strip {
    display: flex;
    gap: 20px;
    width: max-content;
}
/* Outdoor product card — white with image */
.lw-ocard {
    background: #fff;
    border-radius: 20px;
    width: 340px;
    min-width: 340px;
    display: flex;
    flex-direction: column;
    scroll-snap-align: start;
    box-shadow: 0 0 0 1px rgba(0,0,0,0.04), 0 4px 24px rgba(0,0,0,0.06);
    transition: transform 0.4s cubic-bezier(.25,.46,.45,.94),
                box-shadow 0.4s cubic-bezier(.25,.46,.45,.94);
    overflow: hidden;
}
.lw-ocard:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.1);
}
.lw-ocard-img {
    width: 100%;
    height: 200px;
    overflow: hidden;
    background: #f0f0f0;
}
.lw-ocard-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}
.lw-ocard:hover .lw-ocard-img img {
    transform: scale(1.04);
}
/* Text inside ocard */
.lw-ocard .lw-prod-label {
    color: #86868b;
    padding: 24px 24px 0;
    margin-bottom: 6px;
}
.lw-ocard .lw-prod-name {
    color: #1d1d1f;
    padding: 0 24px;
    margin-bottom: 8px;
}
.lw-ocard .lw-prod-dim {
    color: #6e6e73;
    padding: 0 24px;
    margin-bottom: 10px;
}
.lw-ocard .lw-prod-exp {
    color: #6e6e73;
    padding: 0 24px;
    flex: 1;
}
.lw-ocard .lw-prod-price {
    color: #1d1d1f;
    padding: 0 24px;
    margin-top: 14px;
    margin-bottom: 12px;
}
.lw-ocard .lw-prod-price span {
    color: #86868b;
}
.lw-ocard .lw-prod-links {
    border-top: 1px solid rgba(0,0,0,0.08);
    padding: 14px 24px 20px;
    margin-top: auto;
}
.lw-ocard .lw-prod-sqft {
    background: rgba(0,0,0,0.05);
    color: #6e6e73;
}
/* Bespoke — dark card inside white outdoor section */
.lw-collection--outdoor .lw-bespoke {
    background: #1d1d1f;
    border: 1px solid rgba(255,255,255,0.06);
}
.lw-collection--outdoor .lw-bespoke .lw-col-eyebrow {
    color: #86868b;
}
/* Bespoke Engineering block */
.lw-bespoke {
    max-width: 1120px;
    margin: 80px auto 0;
    padding: 60px 48px;
    background: linear-gradient(135deg, #1d1d1f 0%, #111 100%);
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,0.06);
}
.lw-bespoke-head {
    margin-bottom: 32px;
}
.lw-bespoke-title {
    font-size: 2rem;
    font-weight: 700;
    color: #f5f5f7;
    letter-spacing: -0.025em;
    font-family: var(--lw-font);
    margin-bottom: 8px;
}
.lw-bespoke-q {
    font-size: 1.1rem;
    font-weight: 500;
    color: #a1a1a6;
    font-family: var(--lw-font);
    font-style: italic;
}
.lw-bespoke-body {}
.lw-bespoke-desc {
    font-size: 0.92rem;
    color: #86868b;
    line-height: 1.65;
    font-family: var(--lw-font);
    margin-bottom: 16px;
    max-width: 720px;
}
.lw-bespoke-list {
    list-style: none;
    padding: 0;
    margin: 24px 0 32px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.lw-bespoke-list li {
    font-size: 0.88rem;
    color: #a1a1a6;
    font-family: var(--lw-font);
    padding-left: 20px;
    position: relative;
}
.lw-bespoke-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 7px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #0071e3;
}
.lw-bespoke-list li strong {
    color: #f5f5f7;
    font-weight: 600;
}
.lw-bespoke-cta {
    display: inline-flex;
    flex-direction: column;
    gap: 4px;
    background: #0071e3;
    color: #fff;
    font-size: 0.95rem;
    font-weight: 600;
    font-family: var(--lw-font);
    padding: 16px 32px;
    border-radius: 14px;
    text-decoration: none;
    transition: background 0.3s ease, transform 0.3s ease;
}
.lw-bespoke-cta:hover {
    background: #0077ED;
    transform: translateY(-2px);
}
.lw-bespoke-cta span {
    font-size: 0.76rem;
    font-weight: 400;
    color: rgba(255,255,255,0.7);
}

/* ========================================
   WHY PIXELSPOT — Grid cards
   ======================================== */
.lw-why {
    padding: 100px 24px 80px;
    background: var(--lw-bg);
}
.lw-why-head {
    text-align: center;
    margin-bottom: 56px;
}
.lw-why-head h2 { margin-bottom: 14px; }
.lw-why-head .lw-link-blue { color: var(--lw-blue); }

.lw-why-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 1080px;
    margin: 0 auto;
}
.lw-why-card {
    background: var(--lw-bg-alt);
    border: 1px solid var(--lw-card-border);
    border-radius: var(--lw-radius);
    padding: 36px 28px;
    text-align: left;
    transition: transform 0.4s cubic-bezier(.25,.46,.45,.94),
                box-shadow 0.4s cubic-bezier(.25,.46,.45,.94);
}
.lw-why-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 48px rgba(0,0,0,0.06);
}
.lw-why-icon {
    font-size: 2.4rem;
    margin-bottom: 16px;
}
.lw-why-card h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--lw-text);
    margin-bottom: 8px;
    font-family: var(--lw-font);
}
.lw-why-card p {
    font-size: 0.85rem;
    color: var(--lw-text-sec);
    line-height: 1.55;
    font-family: var(--lw-font);
}

/* ========================================
   GET TO KNOW — Dark feature tiles grid
   ======================================== */
.lw-know {
    padding: 100px 24px 80px;
    background: var(--lw-bg-dark);
}
.lw-know-head {
    text-align: center;
    margin-bottom: 56px;
}
.lw-know-head .lw-sec-title { color: #f5f5f7; }
.lw-know-head .lw-sec-sub { color: #a1a1a6; }

.lw-know-grid {
    display: flex;
    gap: 20px;
    width: max-content;
    animation: knowScroll 30s linear infinite;
    padding: 0 20px;
}
.lw-know-track {
    overflow: hidden;
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
    mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
    cursor: grab;
}
.lw-know-track:active { cursor: grabbing; }
.lw-know-track:hover .lw-know-grid,
.lw-know-track.is-dragging .lw-know-grid {
    animation-play-state: paused;
}
@keyframes knowScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.lw-know-tile {
    background: #1d1d1f;
    border-radius: var(--lw-radius);
    padding: 36px 28px 32px;
    display: flex;
    flex-direction: column;
    min-height: 200px;
    flex: 0 0 300px;
    width: 300px;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.06);
    transition: transform 0.4s cubic-bezier(.25,.46,.45,.94),
                box-shadow 0.4s cubic-bezier(.25,.46,.45,.94),
                border-color 0.4s;
}
.lw-know-tile:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 48px rgba(0,0,0,0.5);
    border-color: rgba(255,255,255,0.1);
}
.lw-know-label {
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--lw-blue);
    margin-bottom: 6px;
    font-family: var(--lw-font);
}
.lw-know-tile h3 {
    font-size: 1.3rem;
    font-weight: 700;
    color: #f5f5f7;
    margin-bottom: 10px;
    font-family: var(--lw-font);
}
.lw-know-tile p {
    font-size: 0.84rem;
    color: #a1a1a6;
    line-height: 1.55;
    flex: 1;
    font-family: var(--lw-font);
}
.lw-know-ico {
    position: absolute;
    bottom: 18px;
    right: 20px;
    opacity: 0.18;
    transition: opacity 0.4s, transform 0.4s;
}
.lw-know-ico svg { fill: #1d1d1f; stroke: #1d1d1f; stroke-width: 1.5; }
.lw-know-tile:hover .lw-know-ico {
    opacity: 0.35;
    transform: scale(1.1);
}
/* Know tile SVG animations */
.kn-px { fill: #1d1d1f; stroke: none; animation: pxFade 2.4s ease infinite; }
.kn-px:nth-child(2) { animation-delay: 0.15s; }
.kn-px:nth-child(3) { animation-delay: 0.3s; }
.kn-px:nth-child(4) { animation-delay: 0.45s; }
.kn-px:nth-child(5) { animation-delay: 0.6s; }
.kn-px:nth-child(6) { animation-delay: 0.75s; }
.kn-px:nth-child(7) { animation-delay: 0.9s; }
.kn-px:nth-child(8) { animation-delay: 1.05s; }
.kn-px:nth-child(9) { animation-delay: 1.2s; }
.kn-sun { fill: #1d1d1f; stroke: none; }
.kn-rays line { stroke: #1d1d1f; stroke-width: 2; stroke-linecap: round; animation: knSpin 8s linear infinite; transform-origin: 20px 20px; }
.kn-shield { fill: none; stroke: #1d1d1f; stroke-width: 1.8; }
.kn-check { stroke: #1d1d1f; stroke-width: 2.2; animation: knDraw 2s ease infinite; }
.kn-clock-face { fill: none; stroke: #1d1d1f; stroke-width: 1.8; }
.kn-hand-m { stroke: #1d1d1f; stroke-width: 2; stroke-linecap: round; animation: knTick 4s steps(60) infinite; transform-origin: 20px 20px; }
.kn-hand-h { stroke: #1d1d1f; stroke-width: 2.5; stroke-linecap: round; }
.kn-dot { fill: #1d1d1f; }
.kn-wrench { stroke: #1d1d1f; stroke-width: 1.8; }
.kn-mag { fill: #1d1d1f; stroke: none; animation: knPulse 2s ease infinite; }
.kn-panel { fill: none; stroke: #1d1d1f; stroke-width: 1.8; }
.kn-p2 { animation: knSlide 3s ease infinite; }
.kn-seam { stroke: #1d1d1f; stroke-width: 1; opacity: 0.4; animation: knBlink 2s ease infinite; }
@keyframes knSpin { to { transform: rotate(360deg); } }
@keyframes knDraw { 0%,60% { stroke-dasharray: 24; stroke-dashoffset: 24; } 80%,100% { stroke-dashoffset: 0; } }
@keyframes knTick { to { transform: rotate(360deg); } }
@keyframes knPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }
@keyframes knSlide { 0%,100% { transform: translateX(0); } 50% { transform: translateX(-3px); } }
@keyframes knBlink { 0%,100% { opacity: 0.4; } 50% { opacity: 0; } }

/* ========================================
   APPLICATIONS — Use case grid
   ======================================== */
.lw-apps {
    padding: 100px 24px 80px;
    background: var(--lw-bg-alt);
}
.lw-apps-head {
    text-align: center;
    margin-bottom: 56px;
}
.lw-apps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 1080px;
    margin: 0 auto;
}
.lw-app-card {
    background: var(--lw-white);
    border: 1px solid var(--lw-card-border);
    border-radius: var(--lw-radius);
    padding: 36px 24px;
    text-align: center;
    transition: transform 0.4s cubic-bezier(.25,.46,.45,.94),
                box-shadow 0.4s cubic-bezier(.25,.46,.45,.94);
}
.lw-app-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 48px rgba(0,0,0,0.06);
}
.lw-app-ico {
    margin-bottom: 14px;
    display: flex;
    justify-content: center;
}
.lw-app-ico svg { fill: #1d1d1f; stroke: #1d1d1f; stroke-width: 1.5; }
/* App card SVG classes */
.ap-bld { fill: none; stroke: #1d1d1f; stroke-width: 1.8; }
.ap-b2 { animation: apRise 3s ease infinite; }
.ap-win { fill: #1d1d1f; stroke: none; animation: pxFade 2s ease infinite; }
.ap-win:nth-child(3) { animation-delay: 0.2s; }
.ap-win:nth-child(4) { animation-delay: 0.4s; }
.ap-win:nth-child(5) { animation-delay: 0.6s; }
.ap-win:nth-child(6) { animation-delay: 0.1s; }
.ap-win:nth-child(7) { animation-delay: 0.3s; }
.ap-win:nth-child(8) { animation-delay: 0.5s; }
.ap-win:nth-child(9) { animation-delay: 0.7s; }
.ap-bag { fill: none; stroke: #1d1d1f; stroke-width: 1.8; }
.ap-handle { stroke: #1d1d1f; stroke-width: 2; }
.ap-stad { stroke: #1d1d1f; stroke-width: 2; }
.ap-field { fill: none; stroke: #1d1d1f; stroke-width: 1.5; }
.ap-flag { stroke: #1d1d1f; stroke-width: 1.8; }
.ap-pennant { fill: #1d1d1f; stroke: none; animation: apWave 2s ease infinite; transform-origin: 20px 15px; }
.ap-temple { fill: none; stroke: #1d1d1f; stroke-width: 1.8; }
.ap-base { fill: none; stroke: #1d1d1f; stroke-width: 1.5; }
.ap-door { fill: none; stroke: #1d1d1f; stroke-width: 1.5; }
.ap-glow { fill: #1d1d1f; animation: knPulse 2.5s ease infinite; }
.ap-screen { fill: none; stroke: #1d1d1f; stroke-width: 1.8; }
.ap-scr-inner { fill: #1d1d1f; opacity: 0.12; animation: apFlicker 3s ease infinite; }
.ap-stand { stroke: #1d1d1f; stroke-width: 2; }
.ap-foot { stroke: #1d1d1f; stroke-width: 2.5; }
.ap-rec { fill: #ff3b30; stroke: none; animation: knPulse 1.5s ease infinite; }
.ap-board { fill: none; stroke: #1d1d1f; stroke-width: 1.8; }
.ap-board-inner { fill: #1d1d1f; opacity: 0.1; animation: apFlicker 4s ease infinite; }
.ap-pole { stroke: #1d1d1f; stroke-width: 2; }
.ap-ground { stroke: #1d1d1f; stroke-width: 2; }
.lw-app-card:hover .lw-app-ico svg { transform: scale(1.08); transition: transform 0.3s ease; }
@keyframes apRise { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-2px); } }
@keyframes apWave { 0%,100% { transform: scaleX(1); } 50% { transform: scaleX(0.9) translateX(1px); } }
@keyframes apFlicker { 0%,100% { opacity: 0.12; } 50% { opacity: 0.25; } }
.lw-app-card h3 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--lw-text);
    margin-bottom: 6px;
    font-family: var(--lw-font);
}
.lw-app-card p {
    font-size: 0.84rem;
    color: var(--lw-text-sec);
    line-height: 1.5;
    font-family: var(--lw-font);
}

/* ========================================
   CTA SECTION — Cinematic
   ======================================== */
.lw-cta {
    text-align: center;
    padding: 120px 24px;
    background: linear-gradient(180deg, var(--lw-bg) 0%, var(--lw-bg-alt) 100%);
    position: relative;
    overflow: hidden;
}
.lw-cta-inner {
    max-width: 600px;
    margin: 0 auto;
}
.lw-cta h2 {
    font-size: clamp(2.2rem, 5vw, 3.5rem);
    font-weight: 700;
    color: var(--lw-text);
    letter-spacing: -0.03em;
    margin-bottom: 16px;
    font-family: var(--lw-font);
}
.lw-cta p {
    font-size: 1.1rem;
    color: var(--lw-text-sec);
    max-width: 480px;
    margin: 0 auto 32px;
    line-height: 1.5;
    font-family: var(--lw-font);
}
.lw-cta-btns {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
}
.lw-btn-blue {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 36px;
    background: var(--lw-blue);
    color: #fff;
    border: none;
    border-radius: 980px;
    font-size: 1.05rem;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.35s cubic-bezier(.25,.46,.45,.94);
    font-family: var(--lw-font);
    position: relative;
    overflow: hidden;
}
.lw-btn-blue::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transition: left 0.5s;
}
.lw-btn-blue:hover {
    background: var(--lw-blue-hover);
    transform: scale(1.05);
    box-shadow: 0 8px 30px rgba(0,113,227,0.3);
}
.lw-btn-blue:hover::before {
    left: 100%;
}

/* ========================================
   QUICK LINKS — Apple Store footer links
   ======================================== */
.lw-quicklinks {
    padding: 48px 24px;
    background: var(--lw-bg-alt);
    border-top: 1px solid var(--lw-card-border);
}
.lw-ql-inner {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    max-width: 980px;
    margin: 0 auto;
}
.lw-ql-col h3 {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--lw-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 12px;
    font-family: var(--lw-font);
}
.lw-ql-col a {
    display: block;
    font-size: 0.82rem;
    color: var(--lw-text-sec);
    text-decoration: none;
    padding: 4px 0;
    transition: color 0.2s;
    font-family: var(--lw-font);
}
.lw-ql-col a:hover {
    color: var(--lw-blue);
}

/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 1024px) {
    .lw-grid .lw-card,
    .lw-card--featured {
        flex: 0 0 300px !important;
        min-width: 300px !important;
    }
    .lw-pitch-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .lw-promo {
        font-size: 0.78rem;
        padding: 12px 16px;
    }
    .lw-hero {
        padding: 70px 20px 20px;
        min-height: auto;
    }
    .lw-hero-links {
        flex-direction: column;
        gap: 10px;
    }

    .lw-pitch {
        padding: 80px 16px 64px;
    }
    .lw-pitch-grid {
        grid-template-columns: 1fr;
        max-width: 400px;
    }

    .lw-lineup {
        padding: 64px 0 48px;
    }
    .lw-lineup-head {
        padding: 0 16px;
    }
    .lw-grid {
        padding: 0 16px 16px;
        gap: 14px;
    }
    .lw-grid .lw-card,
    .lw-card--featured {
        flex: 0 0 280px !important;
        min-width: 280px !important;
    }

    .lw-why, .lw-know, .lw-apps {
        padding: 64px 16px 48px;
    }
    .lw-why-grid,
    .lw-apps-grid {
        grid-template-columns: 1fr;
        max-width: 400px;
        margin: 0 auto;
    }
    .lw-know-tile {
        flex: 0 0 260px;
        width: 260px;
    }

    .lw-collection {
        padding: 64px 16px 48px;
    }
    .lw-series-grid {
        grid-template-columns: 1fr;
        max-width: 480px;
        margin: 0 auto;
        gap: 16px;
    }
    .lw-series-title {
        font-size: 1.5rem;
    }
    .lw-prod-card {
        padding: 28px 22px 24px;
    }
    .lw-series-grid--2col {
        grid-template-columns: 1fr;
    }
    .lw-ocard {
        width: 290px;
        min-width: 290px;
    }
    .lw-ocard-img {
        height: 160px;
    }
    .lw-bespoke {
        padding: 36px 24px;
        margin-top: 48px;
    }
    .lw-bespoke-title {
        font-size: 1.5rem;
    }
    .lw-bespoke-list {
        gap: 12px;
    }
    .lw-bespoke-cta {
        width: 100%;
        text-align: center;
        align-items: center;
    }

    .lw-cta {
        padding: 80px 20px;
    }
    .lw-cta-btns {
        flex-direction: column;
        gap: 14px;
    }
    .lw-btn-blue {
        width: 100%;
        max-width: 280px;
    }

    .lw-ql-inner {
        grid-template-columns: 1fr;
        gap: 28px;
    }
}

@media (max-width: 480px) {
    .lw-card-img {
        min-height: 180px;
    }
    .lw-card--featured .lw-card-img {
        min-height: 200px;
    }
    .lw-card-img img {
        max-height: 170px;
    }
    .lw-card--featured .lw-card-img img {
        max-height: 190px;
    }
    .lw-know-ico svg { width: 36px; height: 36px; }
}

/* ========================================
   DARK THEME OVERRIDES
   ======================================== */
[data-theme="dark"] .lw-promo {
    background: #1d1d1f;
    color: #f5f5f7;
    border-bottom-color: #38383d;
}
[data-theme="dark"] .lw-promo a { color: #2997ff; }

[data-theme="dark"] .lw-pitch {
    background: #1d1d1f;
}
[data-theme="dark"] .lw-pitch-title { color: #f5f5f7; }
[data-theme="dark"] .lw-pitch-desc { color: #a1a1a6; }
[data-theme="dark"] .lw-pitch-card {
    background: #2d2d2d;
    box-shadow: 0 0 0 1px rgba(255,255,255,0.06), 0 4px 16px rgba(0,0,0,0.2);
}
[data-theme="dark"] .lw-pitch-card:hover {
    box-shadow: 0 0 0 1px rgba(255,255,255,0.08), 0 12px 40px rgba(0,0,0,0.35);
}
[data-theme="dark"] .lw-pitch-card h3 { color: #f5f5f7; }
[data-theme="dark"] .lw-pitch-range { color: #86868b; }
[data-theme="dark"] .lw-pitch-detail { color: #a1a1a6; }
[data-theme="dark"] .lw-pitch-dot { background: #48484a; }
[data-theme="dark"] .lw-pitch-dot.active { background: #f5f5f7; }
[data-theme="dark"] .lw-pitch-label { color: #6e6e73; }
[data-theme="dark"] .lw-pitch-anim--pixels .px { fill: #f5f5f7; }
[data-theme="dark"] .lw-pitch-anim--screen .scr-body { stroke: #f5f5f7; }
[data-theme="dark"] .lw-pitch-anim--screen .scr-stand { stroke: #f5f5f7; }
[data-theme="dark"] .lw-pitch-anim--screen .scr-base  { stroke: #f5f5f7; }
[data-theme="dark"] .lw-pitch-anim--screen .scr-glow  { fill: #2997ff; }
[data-theme="dark"] .lw-pitch-anim--venue .ven-arc,
[data-theme="dark"] .lw-pitch-anim--venue .ven-l,
[data-theme="dark"] .lw-pitch-anim--venue .ven-r,
[data-theme="dark"] .lw-pitch-anim--venue .ven-floor { stroke: #f5f5f7; }
[data-theme="dark"] .lw-pitch-anim--venue .ven-dot { fill: #f5f5f7; }
[data-theme="dark"] .lw-pitch-anim--highway .hw-road { stroke: #f5f5f7; }
[data-theme="dark"] .lw-pitch-anim--highway .hw-dash { stroke: #f5f5f7; }

[data-theme="dark"] .lw-lineup {
    background: #000;
}
[data-theme="dark"] .lw-lineup--dark {
    background: #1d1d1f;
}
[data-theme="dark"] .lw-sec-title { color: #f5f5f7; }
[data-theme="dark"] .lw-sec-sub { color: #a1a1a6; }

[data-theme="dark"] .lw-card {
    background: #1d1d1f;
    border-color: #38383d;
}
[data-theme="dark"] .lw-lineup--dark .lw-card {
    background: #2d2d2d;
    border-color: #424245;
}
[data-theme="dark"] .lw-card:hover {
    box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
[data-theme="dark"] .lw-card-name { color: #f5f5f7; }
[data-theme="dark"] .lw-card-desc { color: #a1a1a6; }
[data-theme="dark"] .lw-card-specs { color: #6e6e73; border-top-color: #38383d; }
[data-theme="dark"] .lw-card-price { color: #f5f5f7; }
[data-theme="dark"] .lw-card-price span { color: #a1a1a6; }
[data-theme="dark"] .lw-card-emi { color: #6e6e73; }
[data-theme="dark"] .lw-card-links { border-top-color: #38383d; }
[data-theme="dark"] .lw-card-links .lw-link-blue { color: #2997ff; }
[data-theme="dark"] .lw-card-img {
    background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, transparent 100%);
}

[data-theme="dark"] .lw-tag--blue   { background: rgba(41,151,255,0.15); color: #2997ff; }
[data-theme="dark"] .lw-tag--orange { background: rgba(255,159,10,0.15); color: #ff9f0a; }
[data-theme="dark"] .lw-tag--green  { background: rgba(48,209,88,0.15); color: #30d158; }
[data-theme="dark"] .lw-tag--gray   { background: rgba(174,174,178,0.12); color: #aeaeb2; }

/* Collection section is always dark — no overrides needed */

[data-theme="dark"] .lw-why {
    background: #1d1d1f;
}
[data-theme="dark"] .lw-why-card {
    background: #2d2d2d;
    border-color: #38383d;
}
[data-theme="dark"] .lw-why-card:hover {
    box-shadow: 0 16px 48px rgba(0,0,0,0.4);
}
[data-theme="dark"] .lw-why-card h3 { color: #f5f5f7; }
[data-theme="dark"] .lw-why-card p { color: #a1a1a6; }
[data-theme="dark"] .lw-why-head .lw-link-blue { color: #2997ff; }

[data-theme="dark"] .lw-apps {
    background: #000;
}
[data-theme="dark"] .lw-app-card {
    background: #1d1d1f;
    border-color: #38383d;
}
[data-theme="dark"] .lw-app-card:hover {
    box-shadow: 0 16px 48px rgba(0,0,0,0.4);
}
[data-theme="dark"] .lw-app-card h3 { color: #f5f5f7; }
[data-theme="dark"] .lw-app-card p { color: #a1a1a6; }
[data-theme="dark"] .lw-app-ico svg { fill: #f5f5f7; stroke: #f5f5f7; }
[data-theme="dark"] .lw-know-ico svg { fill: #f5f5f7; stroke: #f5f5f7; }
[data-theme="dark"] .kn-px,
[data-theme="dark"] .kn-sun,
[data-theme="dark"] .kn-dot,
[data-theme="dark"] .kn-mag,
[data-theme="dark"] .ap-win,
[data-theme="dark"] .ap-glow { fill: #f5f5f7; }
[data-theme="dark"] .ap-scr-inner { fill: #f5f5f7; }
[data-theme="dark"] .ap-board-inner { fill: #f5f5f7; }
[data-theme="dark"] .ap-pennant { fill: #f5f5f7; }

[data-theme="dark"] .lw-cta {
    background: linear-gradient(180deg, #000 0%, #1d1d1f 100%);
}
[data-theme="dark"] .lw-cta h2 { color: #f5f5f7; }
[data-theme="dark"] .lw-cta p { color: #a1a1a6; }

[data-theme="dark"] .lw-quicklinks {
    background: #1d1d1f;
    border-top-color: #38383d;
}
[data-theme="dark"] .lw-ql-col h3 { color: #f5f5f7; }
[data-theme="dark"] .lw-ql-col a { color: #a1a1a6; }
[data-theme="dark"] .lw-ql-col a:hover { color: #2997ff; }

/* ══════════════════════════════════════════════
   APPLE SCROLL ANIMATIONS
   ══════════════════════════════════════════════ */

/* ── Scroll Progress Bar ── */
.scroll-progress-bar {
    position: fixed; top: 0; left: 0; height: 3px; width: 0%;
    background: linear-gradient(90deg, var(--lw-blue), #5ac8fa, var(--lw-blue));
    z-index: 10000;
    box-shadow: 0 0 8px rgba(0,113,227,0.4);
    transition: background 0.5s;
}

/* ── Keyframes ── */
@keyframes glowFloat {
    0% { transform: translate(0,0) scale(1); }
    50% { transform: translate(30px,-20px) scale(1.15); }
    100% { transform: translate(-20px,15px) scale(0.9); }
}
@keyframes shimmer {
    0% { background-position: -200% center; }
    100% { background-position: 200% center; }
}

/* ── Hero Zoom ── */
.hero-zoom {
    transition: transform 0.15s ease-out, filter 0.15s ease-out;
    will-change: transform, filter;
}

/* ── Stagger Children ── */
.stagger-child {
    opacity: 0;
    transform: translateY(25px);
    transition: opacity 0.6s cubic-bezier(0.25,0.46,0.45,0.94),
                transform 0.6s cubic-bezier(0.25,0.46,0.45,0.94);
}
.stagger-child.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ── Fade ── */
.ds-fade {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s cubic-bezier(0.25,0.46,0.45,0.94),
                transform 0.8s cubic-bezier(0.25,0.46,0.45,0.94);
}
.ds-fade.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ── Text Reveal ── */
.text-reveal .reveal-word {
    display: inline-block;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.4s ease, transform 0.4s ease;
    margin-right: 0.3em;
}
.text-reveal.words-visible .reveal-word {
    opacity: 1;
    transform: translateY(0);
}

/* ── Parallax / Scale / Tilt ── */
.parallax-img { will-change: transform; }
.scale-on-scroll { will-change: transform, opacity; }
.tilt-card { transition: transform 0.3s ease; will-change: transform; }

/* ── Glow Orbs ── */
.glow-orbs .orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.5;
    animation: glowFloat 8s ease-in-out infinite alternate;
}

/* ── Hero shimmer ── */
.lw-hero-title.hero-zoom {
    background: linear-gradient(135deg, #f5f5f7 0%, #a1a1a6 50%, #f5f5f7 100%);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: shimmer 4s linear infinite;
}

/* ── Mobile ── */
@media (max-width: 734px) {
    .scroll-progress-bar { height: 2px; }
}
