/* ============================================================
   WUFFUN MARKETING LANDING PAGE v3 — Animated SVG Pets
   ============================================================ */

/* GLOBAL RESETS */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
.hidden { display: none !important; }

/* ===== APP THEME VARIABLES ===== */
/* Dark theme (default) */
:root {
  --bg:#0A0A0C;--bg2:#111114;--card:#18181C;--card2:#1E1E24;--card3:#28282F;
  --ink:#F0F0F2;--ink2:#9A9AA8;--ink3:#5C5C6A;
  --accent:#ff4d6d;--accent2:#ff758f;--accent-bg:rgba(255,77,109,.12);
  --green:#2ecc71;--blue:#3498db;--gold:#f1c40f;
  --radius:14px;--radius-sm:8px;
  --topbar-h:52px;--bnav-h:56px;
  --safe-top:env(safe-area-inset-top,0px);--safe-bot:env(safe-area-inset-bottom,0px);
  --font:'Sora',sans-serif;--font-brand:'Bricolage Grotesque',sans-serif;
  --border-subtle:rgba(255,255,255,.06);
  --shadow-card:0 2px 12px rgba(0,0,0,.4);
}
/* Light theme — warm, designed, NOT inverted */
[data-theme="light"] {
  --bg:#FAFAF8;--bg2:#F2F0EC;--card:#FFFFFF;--card2:#F7F5F1;--card3:#EDEBE6;
  --ink:#1A1A1F;--ink2:#5A5A66;--ink3:#9A9AA2;
  --accent:#E63956;--accent2:#ff4d6d;--accent-bg:rgba(230,57,86,.08);
  --border-subtle:rgba(0,0,0,.06);
  --shadow-card:0 2px 12px rgba(0,0,0,.06);
}
html{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-tap-highlight-color:transparent;overflow:hidden;height:100%}
body{height:100%;overflow:hidden;background:var(--bg)}
img{display:block;max-width:100%}
button,input,textarea,select{font-family:inherit;border:none;outline:none;background:none;color:inherit}
a{color:inherit}

/* ===== LANDING PAGE VARIABLES ===== */
:root {
  --wf-cream: #F9F3EB;
  --wf-terra: #C85A3C;
  --wf-gold: #D4A853;
  --wf-bark: #1B1612;
  --wf-sage: #7A8B6F;
  --wf-warm: #E8B86D;
  --wf-blush: #E8707A;
  --wf-stone: #B5ADA5;
  --wf-dog: #D4954A;
}

/* LANDING CONTAINER */
.wf-land {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--wf-cream);
  overflow-y: auto; overflow-x: hidden;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  font-family: 'DM Sans', sans-serif;
  color: var(--wf-bark);
}
.wf-land.hidden { display: none !important; }
.wf-land *, .wf-land *::before, .wf-land *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* GRAIN */
.wf-grain {
  position: fixed; inset: 0; pointer-events: none; z-index: 1;
  opacity: .03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* FLOATING PAWS */
.wf-paws { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.wf-paw { position: absolute; color: var(--wf-terra); }
.wf-paw-1 { width: 40px; top: 8%; left: 5%; animation: wfPawFloat 8s ease-in-out infinite; }
.wf-paw-2 { width: 30px; top: 25%; right: 8%; animation: wfPawFloat 10s ease-in-out infinite 1s; }
.wf-paw-3 { width: 50px; top: 50%; left: 12%; animation: wfPawFloat 12s ease-in-out infinite 2s; }
.wf-paw-4 { width: 25px; top: 65%; right: 15%; animation: wfPawFloat 9s ease-in-out infinite 3s; }
.wf-paw-5 { width: 35px; top: 80%; left: 80%; animation: wfPawFloat 11s ease-in-out infinite 0.5s; }
.wf-paw-6 { width: 28px; top: 40%; left: 60%; animation: wfPawFloat 13s ease-in-out infinite 4s; }
@keyframes wfPawFloat {
  0%, 100% { transform: translateY(0) rotate(0deg); opacity: .5; }
  25% { transform: translateY(-20px) rotate(10deg); opacity: .8; }
  50% { transform: translateY(-8px) rotate(-5deg); opacity: .6; }
  75% { transform: translateY(-25px) rotate(8deg); opacity: .9; }
}

/* NAV */
.wf-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: rgba(249,243,235,.85);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(27,22,18,.06);
  transition: transform .3s ease;
}
.wf-nav-in {
  max-width: 1100px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px;
}
.wf-logo { display: flex; align-items: center; gap: 8px; text-decoration: none; color: var(--wf-bark); }
.wf-logo-icon { flex-shrink: 0; }
.wf-logo-text { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 1.3rem; }
.wf-nav-mid { display: flex; gap: 32px; }
.wf-nav-mid a { text-decoration: none; color: var(--wf-bark); font-size: .9rem; font-weight: 500; opacity: .7; transition: opacity .2s; }
.wf-nav-mid a:hover { opacity: 1; }
.wf-nav-end { display: flex; align-items: center; gap: 16px; }
.wf-nav-login { text-decoration: none; color: var(--wf-bark); font-size: .9rem; font-weight: 500; opacity: .7; }
.wf-nav-cta {
  background: var(--wf-bark); color: var(--wf-cream);
  border: none; padding: 10px 22px; border-radius: 50px;
  font-size: .85rem; font-weight: 600; cursor: pointer;
  transition: transform .2s, box-shadow .2s;
}
.wf-nav-cta:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(27,22,18,.2); }
.wf-burger { display: none; background: none; border: none; cursor: pointer; width: 28px; height: 20px; position: relative; }
.wf-burger span { display: block; width: 100%; height: 2px; background: var(--wf-bark); position: absolute; left: 0; transition: all .3s; }
.wf-burger span:first-child { top: 0; }
.wf-burger span:last-child { bottom: 0; }
.wf-burger.open span:first-child { top: 50%; transform: translateY(-50%) rotate(45deg); }
.wf-burger.open span:last-child { bottom: 50%; transform: translateY(50%) rotate(-45deg); }

/* MOBILE DRAWER */
.wf-drawer {
  position: fixed; top: 56px; left: 0; right: 0; z-index: 99;
  background: var(--wf-cream); padding: 24px;
  display: flex; flex-direction: column; gap: 16px;
  border-bottom: 1px solid rgba(27,22,18,.08);
  transform: translateY(-10px); opacity: 0;
  transition: transform .3s ease, opacity .3s ease;
}
.wf-drawer.visible { transform: translateY(0); opacity: 1; display: flex !important; }
.wf-drawer.hidden { display: none !important; }
.wf-dr-link { text-decoration: none; color: var(--wf-bark); font-size: 1.1rem; font-weight: 500; padding: 8px 0; }
.wf-dr-cta {
  background: var(--wf-bark); color: var(--wf-cream);
  border: none; padding: 14px; border-radius: 50px;
  font-size: 1rem; font-weight: 600; cursor: pointer; text-align: center;
}

/* REVEAL ANIMATION */
.wf-reveal {
  opacity: 0; transform: translateY(30px);
  transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
  transition-delay: var(--d, 0s);
}
.wf-reveal.visible { opacity: 1; transform: translateY(0); }

/* ======= HERO ======= */
/* Hero Background Video */
.wf-hero-video-bg {
  position: absolute; top: 0; left: 0; width: 100%; height: 100vh;
  z-index: 0; overflow: hidden;
}
.wf-hero-video-bg video {
  width: 100%; height: 100%; object-fit: cover;
  opacity: .35;
}
.wf-hero-video-overlay {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  background: linear-gradient(180deg, var(--wf-cream) 0%, transparent 30%, transparent 70%, var(--wf-cream) 100%);
}
.wf-hero {
  min-height: 100vh; min-height: 100dvh;
  display: grid; grid-template-columns: 1fr 1fr;
  align-items: center; gap: 40px;
  max-width: 1100px; margin: 0 auto;
  padding: 100px 24px 60px;
  position: relative; z-index: 2;
}
.wf-hero-tag {
  font-family: 'Caveat', cursive; font-size: 1.1rem;
  color: var(--wf-terra); opacity: .7; margin-bottom: 16px;
}
.wf-hero-h1 { display: flex; flex-direction: column; }
.wf-h1-line {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.4rem, 5.5vw, 4rem);
  font-weight: 800; line-height: 1.1;
  color: var(--wf-bark);
}
.wf-h1-accent {
  font-style: italic; color: var(--wf-terra);
}
.wf-hero-body {
  margin-top: 20px; font-size: 1.05rem; line-height: 1.65;
  color: var(--wf-bark); opacity: .65; max-width: 420px;
}
.wf-hero-actions { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; }
.wf-btn-fill {
  background: var(--wf-bark); color: var(--wf-cream);
  border: none; padding: 14px 28px; border-radius: 50px;
  font-size: .95rem; font-weight: 600; cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  font-family: 'DM Sans', sans-serif;
}
.wf-btn-fill:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(27,22,18,.2); }
.wf-btn-outline {
  background: transparent; color: var(--wf-bark);
  border: 1.5px solid rgba(27,22,18,.2); padding: 14px 28px; border-radius: 50px;
  font-size: .95rem; font-weight: 500; cursor: pointer;
  transition: border-color .2s, background .2s;
  font-family: 'DM Sans', sans-serif;
}
.wf-btn-outline:hover { border-color: var(--wf-bark); background: rgba(27,22,18,.03); }
.wf-btn-lg { padding: 18px 40px; font-size: 1.05rem; }
.wf-hero-proof { display: flex; align-items: center; gap: 12px; margin-top: 24px; }
.wf-proof-faces { display: flex; }
.wf-proof-faces img {
  width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--wf-cream);
  object-fit: cover; margin-left: -8px;
}
.wf-proof-faces img:first-child { margin-left: 0; }
.wf-hero-proof span { font-size: .85rem; color: var(--wf-bark); opacity: .5; }

/* ===== MULTI-PET HERO SCENE ===== */
.wf-hero-right { display: flex; align-items: center; justify-content: center; position: relative; }
.wf-pet-scene {
  position: relative; width: 100%; max-width: 480px; height: 380px;
}

/* Pet positioning */
.wf-pet { position: absolute; }
.wf-pet-dog { width: 220px; bottom: 0; left: 50%; transform: translateX(-55%); z-index: 3; }
.wf-pet-cat { width: 100px; bottom: 10px; right: 0; z-index: 2; }
.wf-pet-corgi { width: 110px; bottom: 5px; left: -5px; z-index: 4; }
.wf-pet-bird { width: 55px; top: 30px; right: 30px; z-index: 5; }

/* ===== DOG ANIMATIONS ===== */
.wf-anim-wag { transform-origin: 155px 145px; animation: wfWag .4s ease-in-out infinite alternate; }
@keyframes wfWag { 0% { transform: rotate(-15deg); } 100% { transform: rotate(15deg); } }

.wf-anim-blink { animation: wfBlink 4s ease-in-out infinite; }
@keyframes wfBlink {
  0%, 42%, 46%, 100% { transform: scaleY(1); }
  44% { transform: scaleY(0.08); }
}

.wf-anim-ear-l { transform-origin: 72px 110px; animation: wfEarL 3s ease-in-out infinite; }
@keyframes wfEarL { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(-4deg); } }
.wf-anim-ear-r { transform-origin: 148px 110px; animation: wfEarR 3.2s ease-in-out infinite; }
@keyframes wfEarR { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(4deg); } }

.wf-anim-tongue { transform-origin: 110px 126px; animation: wfTongue 2s ease-in-out infinite; }
@keyframes wfTongue {
  0%, 100% { transform: scaleY(1); }
  50% { transform: scaleY(.85) translateY(-1px); }
}

.wf-anim-heart {
  transform-origin: 110px 65px;
  animation: wfHeartBeat 1.5s ease-in-out infinite;
}
@keyframes wfHeartBeat {
  0%, 100% { transform: scale(1); opacity: .75; }
  15% { transform: scale(1.25); opacity: 1; }
  30% { transform: scale(1); opacity: .75; }
  45% { transform: scale(1.15); opacity: .9; }
}

/* ===== CAT ANIMATIONS ===== */
.wf-anim-cat-tail { transform-origin: 118px 130px; animation: wfCatTail 3s ease-in-out infinite; }
@keyframes wfCatTail { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(-12deg); } }

.wf-anim-cat-blink { animation: wfCatBlink 5s ease-in-out infinite; }
@keyframes wfCatBlink {
  0%, 48%, 52%, 100% { transform: scaleY(1); }
  50% { transform: scaleY(0.05); }
}

.wf-anim-whiskers { animation: wfWhiskers 4s ease-in-out infinite; }
@keyframes wfWhiskers {
  0%, 100% { transform: scaleX(1); }
  50% { transform: scaleX(1.08); }
}

/* ===== CORGI ANIMATIONS ===== */
.wf-anim-bounce { animation: wfBounce 1.8s ease-in-out infinite; }
@keyframes wfBounce {
  0%, 100% { transform: translateY(0); }
  40% { transform: translateY(-8px); }
  60% { transform: translateY(-3px); }
}

.wf-anim-corgi-wag { transform-origin: 118px 60px; animation: wfCorgiWag .3s ease-in-out infinite alternate; }
@keyframes wfCorgiWag { 0% { transform: rotate(-20deg); } 100% { transform: rotate(20deg); } }

.wf-anim-corgi-ear-l { transform-origin: 40px 42px; animation: wfCorgiEarL 2s ease-in-out infinite; }
@keyframes wfCorgiEarL { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(-3deg); } }
.wf-anim-corgi-ear-r { transform-origin: 64px 42px; animation: wfCorgiEarR 2.3s ease-in-out infinite; }
@keyframes wfCorgiEarR { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(3deg); } }

.wf-anim-corgi-tongue { animation: wfCorgiTongue 2.5s ease-in-out infinite; }
@keyframes wfCorgiTongue {
  0%, 100% { transform: scaleY(1); }
  50% { transform: scaleY(.8); }
}

/* ===== BIRD ANIMATIONS ===== */
.wf-anim-bird-bob { animation: wfBirdBob 2s ease-in-out infinite; }
@keyframes wfBirdBob { 0%, 100% { transform: translateY(0) rotate(0); } 50% { transform: translateY(-5px) rotate(-3deg); } }

.wf-anim-wing-flap { transform-origin: 30px 52px; animation: wfWingFlap 1.2s ease-in-out infinite; }
@keyframes wfWingFlap { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(-12deg); } }

/* ===== PUG ANIMATIONS (reels section) ===== */
.wf-anim-pug-tilt { animation: wfPugTilt 3s ease-in-out infinite; }
@keyframes wfPugTilt { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(5deg); } }
.wf-anim-pug-tail { transform-origin: 88px 88px; animation: wfPugTailWag .35s ease-in-out infinite alternate; }
@keyframes wfPugTailWag { 0% { transform: rotate(-10deg); } 100% { transform: rotate(10deg); } }

/* ===== FLOATING ELEMENTS ===== */
.wf-float-bone {
  position: absolute; width: 40px; top: 5%; right: 5%;
  animation: wfFloatItem 5s ease-in-out infinite;
}
.wf-float-star {
  position: absolute; width: 24px; top: 15%; left: 5%;
  animation: wfFloatItem 6s ease-in-out infinite 1s;
}
.wf-float-paw-sm {
  position: absolute; width: 28px; bottom: 25%; right: 10%;
  animation: wfFloatItem 7s ease-in-out infinite 2s;
}
.wf-float-fish {
  position: absolute; width: 35px; top: 25%; left: 15%;
  animation: wfFloatItem 8s ease-in-out infinite 1.5s;
}
@keyframes wfFloatItem {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  33% { transform: translateY(-14px) rotate(10deg); }
  66% { transform: translateY(-6px) rotate(-6deg); }
}

/* MARQUEE */
.wf-marquee {
  padding: 20px 0; overflow: hidden;
  border-top: 1px solid rgba(27,22,18,.06);
  border-bottom: 1px solid rgba(27,22,18,.06);
  position: relative; z-index: 2;
}
.wf-marquee-track {
  display: flex; gap: 24px; white-space: nowrap;
  animation: wfMarquee 25s linear infinite;
  font-family: 'Playfair Display', serif;
  font-size: 1rem; font-weight: 500; color: var(--wf-bark); opacity: .35;
}
.wf-mq-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--wf-terra); opacity: .4; align-self: center; flex-shrink: 0; }
@keyframes wfMarquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ABOUT */
.wf-about { padding: 100px 24px; max-width: 1100px; margin: 0 auto; position: relative; z-index: 2; }
.wf-about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.wf-eyebrow {
  font-family: 'Caveat', cursive; font-size: 1.1rem;
  color: var(--wf-terra); margin-bottom: 12px;
}
.wf-eyebrow-light { color: var(--wf-warm); }
.wf-about h2, .wf-features h2, .wf-reels-sec h2, .wf-shop-sec h2, .wf-stories h2, .wf-comm-sec h2, .wf-final-cta h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800; line-height: 1.15;
  color: var(--wf-bark);
}
.wf-reels-sec h2, .wf-comm-sec h2 { color: var(--wf-cream); }
.wf-about-body { margin-top: 16px; font-size: 1rem; line-height: 1.7; opacity: .65; max-width: 480px; }
.wf-about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.wf-astat {
  background: rgba(27,22,18,.03); border-radius: 16px; padding: 28px 20px;
  text-align: center; border: 1px solid rgba(27,22,18,.05);
}
.wf-astat strong {
  display: block; font-family: 'Playfair Display', serif;
  font-size: 1.8rem; font-weight: 800; color: var(--wf-terra);
}
.wf-astat span { font-size: .85rem; opacity: .5; margin-top: 4px; display: block; }

/* Cat SVG */
.wf-about-cat {
  position: absolute; right: 0; bottom: -20px; width: 120px; opacity: .5;
  pointer-events: none;
}
.wf-cat-svg { width: 100%; }

/* FEATURES BENTO */
.wf-features { padding: 100px 24px; max-width: 1100px; margin: 0 auto; position: relative; z-index: 2; }
.wf-feat-header { margin-bottom: 48px; }
.wf-bento { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.wf-bento-card {
  background: rgba(27,22,18,.02); border: 1px solid rgba(27,22,18,.06);
  border-radius: 20px; padding: 28px; overflow: hidden;
  transition: transform .3s ease, box-shadow .3s ease;
}
.wf-bento-card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(27,22,18,.08); }
.wf-bc-1, .wf-bc-4 { grid-column: span 2; }
.wf-bc-1, .wf-bc-4 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: center; }
.wf-bc-illust { display: flex; align-items: center; justify-content: center; }
.wf-bc-illust svg { width: 100%; max-width: 280px; }
.wf-bc-icon-wrap { margin-bottom: 16px; }
.wf-bento-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem; font-weight: 700; margin-bottom: 8px;
}
.wf-bento-card p { font-size: .9rem; line-height: 1.6; opacity: .6; }

/* SVG animations in bento */
.wf-swipe-arrow { animation: wfSwipeArrow 2s ease-in-out infinite; }
@keyframes wfSwipeArrow {
  0%, 100% { transform: translateX(0); opacity: .6; }
  50% { transform: translateX(8px); opacity: 1; }
}
.wf-ai-sparkle { animation: wfSparkle 2s ease-in-out infinite; }
.wf-ai-sparkle2 { animation: wfSparkle 2.5s ease-in-out infinite .5s; }
@keyframes wfSparkle {
  0%, 100% { transform: scale(1) rotate(0deg); opacity: .4; }
  50% { transform: scale(1.3) rotate(20deg); opacity: .8; }
}

/* REELS (dark section) */
.wf-reels-sec {
  background: var(--wf-bark); padding: 100px 24px;
  position: relative; z-index: 2; overflow: hidden;
}
.wf-reels-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center;
}
.wf-reels-text { color: var(--wf-cream); }
.wf-reels-text p { opacity: .6; line-height: 1.7; margin-top: 16px; font-size: 1rem; color: var(--wf-cream); }
.wf-reels-checks { margin-top: 28px; display: flex; flex-direction: column; gap: 12px; }
.wf-rc { display: flex; align-items: center; gap: 10px; font-size: .95rem; color: var(--wf-cream); opacity: .7; }
.wf-rc span { color: var(--wf-terra); font-weight: 700; }
.wf-reels-phone { display: flex; align-items: center; justify-content: center; position: relative; }
/* Phone mockup */
.wf-phone-mockup {
  width: 240px; background: #1B1612; border-radius: 32px;
  padding: 8px; box-shadow: 0 24px 80px rgba(0,0,0,.5);
  position: relative; overflow: hidden;
}
.wf-phone-notch {
  width: 80px; height: 22px; background: #1B1612;
  border-radius: 0 0 14px 14px; margin: 0 auto;
  position: relative; z-index: 10;
}
.wf-phone-screen {
  border-radius: 24px; overflow: hidden;
  position: relative; aspect-ratio: 9/19.5;
  background: #000;
}
.wf-phone-video {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.wf-phone-img { width: 100%; display: block; }

/* Reel UI overlay inside phone */
.wf-reel-ui {
  position: absolute; inset: 0; display: flex;
  flex-direction: column; justify-content: flex-end;
  padding: 12px; z-index: 5;
  background: linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 50%);
}
.wf-reel-sidebar {
  position: absolute; right: 10px; bottom: 80px;
  display: flex; flex-direction: column; gap: 16px; align-items: center;
}
.wf-reel-action { text-align: center; color: #fff; font-size: .65rem; }
.wf-reel-action span { display: block; margin-top: 2px; }
.wf-reel-bottom { color: #fff; }
.wf-reel-user { display: flex; align-items: center; gap: 6px; font-size: .7rem; margin-bottom: 4px; }
.wf-reel-av { width: 22px; height: 22px; border-radius: 50%; background: linear-gradient(135deg, var(--wf-terra), var(--wf-gold)); }
.wf-reel-follow-btn {
  font-size: .6rem; padding: 2px 8px; border: 1px solid #fff;
  border-radius: 4px; margin-left: 4px;
}
.wf-reel-bottom p { font-size: .65rem; opacity: .8; }

/* Pug SVG next to phone */
.wf-pug-svg { position: absolute; width: 80px; right: -20px; bottom: 20px; z-index: 1; }

/* SHOP */
.wf-shop-sec { padding: 100px 24px; position: relative; z-index: 2; }
.wf-shop-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center;
}
.wf-shop-img-wrap { border-radius: 24px; overflow: hidden; }
.wf-shop-img { width: 100%; display: block; }
.wf-shop-text p { margin-top: 16px; font-size: 1rem; line-height: 1.7; opacity: .65; }
.wf-shop-nums { display: flex; gap: 32px; margin-top: 28px; }
.wf-shop-nums div { text-align: center; }
.wf-shop-nums strong {
  display: block; font-family: 'Playfair Display', serif;
  font-size: 1.4rem; font-weight: 800; color: var(--wf-terra);
}
.wf-shop-nums span { font-size: .8rem; opacity: .5; }

/* Hamster SVG */
.wf-shop-hamster { position: absolute; right: 40px; bottom: -30px; width: 80px; opacity: .4; pointer-events: none; }
.wf-hamster-svg { width: 100%; }
.wf-hamster-blink { animation: wfHamsterBlink 3s ease-in-out infinite; }
@keyframes wfHamsterBlink {
  0%, 38%, 42%, 100% { transform: scaleY(1); }
  40% { transform: scaleY(0.05); }
}

/* TESTIMONIALS */
.wf-stories { padding: 100px 24px; max-width: 1100px; margin: 0 auto; position: relative; z-index: 2; }
.wf-stories-header { margin-bottom: 48px; }
.wf-test-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.wf-test-card {
  background: rgba(27,22,18,.02); border: 1px solid rgba(27,22,18,.06);
  border-radius: 20px; padding: 32px;
  transition: transform .3s ease;
}
.wf-test-card:hover { transform: translateY(-4px); }
.wf-test-featured { background: var(--wf-bark); color: var(--wf-cream); border-color: transparent; }
.wf-test-quote {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem; font-style: italic; line-height: 1.6;
  margin-bottom: 24px;
}
.wf-test-featured .wf-test-quote { color: var(--wf-cream); opacity: .9; }
.wf-test-who { display: flex; align-items: center; gap: 12px; }
.wf-test-who img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.wf-test-who strong { display: block; font-size: .9rem; }
.wf-test-who span { font-size: .8rem; opacity: .5; }
.wf-test-featured .wf-test-who span { color: var(--wf-cream); }

/* COMMUNITY */
.wf-comm-sec {
  position: relative; z-index: 2; margin: 0 24px; border-radius: 24px;
  overflow: hidden; height: 400px;
}
.wf-comm-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.wf-comm-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(27,22,18,.7), transparent);
  display: flex; align-items: flex-end; justify-content: center;
  padding: 48px 24px; text-align: center;
}

/* FINAL CTA */
.wf-final-cta {
  padding: 120px 24px; text-align: center;
  position: relative; z-index: 2;
}
.wf-fcta-inner { max-width: 600px; margin: 0 auto; position: relative; }
.wf-fcta-sub { margin-top: 16px; font-size: 1.05rem; opacity: .5; margin-bottom: 28px; }

/* Bunny SVG */
.wf-bunny-svg {
  position: absolute; width: 60px; right: -80px; top: -20px; opacity: .35;
}
.wf-bunny-hop { animation: wfBunnyHop 2s ease-in-out infinite; }
@keyframes wfBunnyHop {
  0%, 100% { transform: translateY(0); }
  40% { transform: translateY(-10px); }
  60% { transform: translateY(-4px); }
}
.wf-bunny-ear-l { transform-origin: 38px 55px; animation: wfBunnyEarL 3s ease-in-out infinite; }
@keyframes wfBunnyEarL { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(-6deg); } }
.wf-bunny-ear-r { transform-origin: 62px 52px; animation: wfBunnyEarR 3.5s ease-in-out infinite; }
@keyframes wfBunnyEarR { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(6deg); } }

/* FOOTER */
.wf-footer {
  border-top: 1px solid rgba(27,22,18,.06);
  padding: 60px 24px 30px; position: relative; z-index: 2;
}
.wf-footer-in {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 2fr; gap: 40px;
}
.wf-footer-logo { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.wf-footer-logo span { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 1.2rem; }
.wf-footer-left p { font-size: .85rem; opacity: .5; }
.wf-footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.wf-footer-cols h5 { font-size: .75rem; text-transform: uppercase; letter-spacing: 1.5px; opacity: .35; margin-bottom: 12px; }
.wf-footer-cols a { display: block; text-decoration: none; color: var(--wf-bark); font-size: .9rem; opacity: .6; padding: 4px 0; transition: opacity .2s; }
.wf-footer-cols a:hover { opacity: 1; }
.wf-footer-bottom {
  max-width: 1100px; margin: 30px auto 0;
  padding-top: 20px; border-top: 1px solid rgba(27,22,18,.06);
  text-align: center; font-size: .8rem; opacity: .35;
}

/* ======= RESPONSIVE ======= */
@media (max-width: 768px) {
  .wf-nav-mid, .wf-nav-end { display: none; }
  .wf-burger { display: block; }
  .wf-hero { grid-template-columns: 1fr; padding: 90px 20px 40px; min-height: auto; gap: 20px; }
  .wf-hero-right { order: -1; max-width: 280px; margin: 0 auto; }
  .wf-pet-scene { height: 260px; max-width: 320px; }
  .wf-pet-dog { width: 160px; }
  .wf-pet-cat { width: 70px; }
  .wf-pet-corgi { width: 80px; }
  .wf-pet-bird { width: 40px; top: 10px; }
  .wf-h1-line { font-size: clamp(2rem, 8vw, 3rem); }
  .wf-about-grid { grid-template-columns: 1fr; gap: 40px; }
  .wf-bento { grid-template-columns: 1fr; }
  .wf-bc-1, .wf-bc-4 { grid-column: span 1; grid-template-columns: 1fr; }
  .wf-reels-inner { grid-template-columns: 1fr; gap: 40px; }
  .wf-reels-phone { order: -1; }
  .wf-shop-inner { grid-template-columns: 1fr; gap: 40px; }
  .wf-test-grid { grid-template-columns: 1fr; }
  .wf-footer-in { grid-template-columns: 1fr; }
  .wf-footer-cols { grid-template-columns: repeat(3, 1fr); }
  .wf-comm-sec { height: 280px; margin: 0 16px; }
  .wf-about-cat { display: none; }
  .wf-shop-hamster { display: none; }
  .wf-bunny-svg { right: -20px; top: -40px; width: 50px; }
  .wf-pug-svg { width: 55px; right: -10px; }
}

@media (max-width: 480px) {
  .wf-hero { padding: 80px 16px 30px; }
  .wf-hero-right { max-width: 240px; }
  .wf-pet-scene { height: 220px; max-width: 260px; }
  .wf-pet-dog { width: 140px; }
  .wf-pet-cat { width: 60px; }
  .wf-pet-corgi { width: 70px; }
  .wf-pet-bird { width: 35px; }
  .wf-about, .wf-features, .wf-stories { padding: 60px 16px; }
  .wf-shop-sec { padding: 60px 16px; }
  .wf-reels-sec { padding: 60px 16px; }
  .wf-final-cta { padding: 80px 16px; }
  .wf-phone-mockup { width: 190px; }
  .wf-shop-nums { gap: 16px; flex-wrap: wrap; }
  .wf-footer-cols { grid-template-columns: 1fr 1fr; }
}


/* ===== LANDING PAGE DARK MODE ===== */
/* Separate aesthetic: deep charcoal, warm amber accents, soft cream text */
.wf-land.wf-dark {
  --wf-cream: #1A1614;
  --wf-bark: #F2EAE0;
  --wf-terra: #E8845C;
  --wf-gold: #E8C07A;
  --wf-sage: #8FA880;
  --wf-stone: #6B635B;
  background: #1A1614;
  color: #F2EAE0;
}
.wf-land.wf-dark .wf-grain { opacity: .03; }
.wf-land.wf-dark .wf-nav {
  background: rgba(26,22,20,.85);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.wf-land.wf-dark .wf-nav.scrolled {
  background: rgba(26,22,20,.95);
  box-shadow: 0 2px 20px rgba(0,0,0,.3);
}
.wf-land.wf-dark .wf-burger span { background: #F2EAE0; }
.wf-land.wf-dark .wf-drawer {
  background: #1A1614;
  border-top: 1px solid rgba(255,255,255,.06);
}
.wf-land.wf-dark .wf-hero-video-bg video { opacity: .25; }
.wf-land.wf-dark .wf-hero-video-overlay {
  background: linear-gradient(180deg, #1A1614 0%, transparent 30%, transparent 70%, #1A1614 100%);
}
.wf-land.wf-dark .wf-btn-fill {
  background: #E8845C; color: #1A1614;
}
.wf-land.wf-dark .wf-btn-fill:hover {
  box-shadow: 0 6px 24px rgba(232,132,92,.3);
}
.wf-land.wf-dark .wf-btn-outline {
  border-color: rgba(242,234,224,.2); color: #F2EAE0;
}
.wf-land.wf-dark .wf-btn-outline:hover {
  border-color: rgba(242,234,224,.4); background: rgba(255,255,255,.04);
}
.wf-land.wf-dark .wf-proof-faces img {
  border-color: #1A1614;
}
.wf-land.wf-dark .wf-marquee {
  background: #151210;
  border-top: 1px solid rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.wf-land.wf-dark .wf-marquee-track span { color: #F2EAE0; }
.wf-land.wf-dark .wf-mq-dot { background: #E8845C; }
.wf-land.wf-dark .wf-eyebrow { color: #E8845C; }
.wf-land.wf-dark .wf-about-body { color: rgba(242,234,224,.6); }
.wf-land.wf-dark .wf-astat {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}
.wf-land.wf-dark .wf-astat strong { color: #E8845C; }
.wf-land.wf-dark .wf-astat span { color: rgba(242,234,224,.5); }
.wf-land.wf-dark .wf-bento-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}
.wf-land.wf-dark .wf-bento-card:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(232,132,92,.2);
}
.wf-land.wf-dark .wf-bc-title { color: #F2EAE0; }
.wf-land.wf-dark .wf-bc-desc { color: rgba(242,234,224,.5); }
.wf-land.wf-dark .wf-bc-icon { background: rgba(232,132,92,.12); color: #E8845C; }
.wf-land.wf-dark .wf-phone-mockup {
  background: #0D0B0A;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.wf-land.wf-dark .wf-phone-notch { background: #0D0B0A; }
.wf-land.wf-dark .wf-reels-sec {
  background: #151210;
}
.wf-land.wf-dark .wf-reels-sec h2 { color: #F2EAE0; }
.wf-land.wf-dark .wf-reels-text p { color: rgba(242,234,224,.65); }
.wf-land.wf-dark .wf-rc { color: rgba(242,234,224,.7); }
.wf-land.wf-dark .wf-rc span { color: #E8845C; }
.wf-land.wf-dark .wf-eyebrow-light { color: #E8845C; }
.wf-land.wf-dark .wf-shop-sec {
  background: #1A1614;
}
.wf-land.wf-dark .wf-shop-nums .wf-shop-num strong { color: #E8845C; }
.wf-land.wf-dark .wf-shop-nums .wf-shop-num span { color: rgba(242,234,224,.5); }
.wf-land.wf-dark .wf-test-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
}
.wf-land.wf-dark .wf-test-card .wf-test-quote { color: rgba(242,234,224,.85); }
.wf-land.wf-dark .wf-test-who strong { color: #F2EAE0; }
.wf-land.wf-dark .wf-test-who span { color: rgba(242,234,224,.5); }
.wf-land.wf-dark .wf-test-text { color: rgba(242,234,224,.7); }
.wf-land.wf-dark .wf-test-name { color: #F2EAE0; }
.wf-land.wf-dark .wf-test-role { color: rgba(242,234,224,.4); }
.wf-land.wf-dark .wf-test-featured {
  background: rgba(232,132,92,.15);
  border: 1px solid rgba(232,132,92,.25);
  color: #F2EAE0;
}
.wf-land.wf-dark .wf-test-featured .wf-test-quote { color: rgba(242,234,224,.9); }
.wf-land.wf-dark .wf-test-featured .wf-test-who span { color: rgba(242,234,224,.6); }
.wf-land.wf-dark .wf-lf-sec {
  background: #151210;
}
.wf-land.wf-dark .wf-lf-stat strong { color: #E8845C; }
.wf-land.wf-dark .wf-lf-stat span { color: rgba(242,234,224,.5); }
.wf-land.wf-dark .wf-lf-step {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}
.wf-land.wf-dark .wf-lf-step-num {
  background: #E8845C; color: #1A1614;
}
.wf-land.wf-dark .wf-lf-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}
.wf-land.wf-dark .wf-lf-card-info h4 { color: #F2EAE0; }
.wf-land.wf-dark .wf-lf-loc { color: rgba(242,234,224,.5); }
.wf-land.wf-dark .wf-community-sec {
  background: #1A1614;
}
.wf-land.wf-dark .wf-final-cta {
  background: #151210;
}
.wf-land.wf-dark .wf-final-cta h2 { color: #F2EAE0; }
.wf-land.wf-dark .wf-final-cta p { color: rgba(242,234,224,.5); }
.wf-land.wf-dark .wf-footer {
  background: #0D0B0A;
  border-top: 1px solid rgba(255,255,255,.06);
}
.wf-land.wf-dark .wf-footer-col h4 { color: #F2EAE0; }
.wf-land.wf-dark .wf-footer-col a { color: rgba(242,234,224,.5); }
.wf-land.wf-dark .wf-footer-col a:hover { color: #E8845C; }
.wf-land.wf-dark .wf-footer-bottom { border-top: 1px solid rgba(255,255,255,.06); color: rgba(242,234,224,.3); }
/* Dark mode theme toggle button on landing */
.wf-theme-toggle {
  position: fixed; bottom: 24px; right: 24px; z-index: 10001;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--wf-bark); color: var(--wf-cream);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; border: none;
  box-shadow: 0 4px 16px rgba(0,0,0,.2);
  transition: all .3s; font-size: 18px;
}
.wf-theme-toggle:hover { transform: scale(1.1); }
.wf-land.wf-dark .wf-theme-toggle {
  background: #F2EAE0; color: #1A1614;
}

/* ===== ONBOARDING ===== */
.onboarding{position:fixed;inset:0;z-index:999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px}
.ob-slides{position:relative;width:100%;max-width:340px;height:420px}
.ob-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;text-align:center;opacity:0;transform:translateX(40px);transition:all .4s ease;pointer-events:none}
.ob-slide.active{opacity:1;transform:none;pointer-events:auto}
.ob-visual{width:240px;height:240px;border-radius:50%;overflow:hidden;margin-bottom:28px;border:3px solid var(--accent)}
.ob-visual img{width:100%;height:100%;object-fit:cover}
.ob-slide h2{font-size:22px;font-family:var(--font-brand);margin-bottom:10px}
.ob-slide p{font-size:14px;color:var(--ink2);line-height:1.6;max-width:280px}
.ob-dots{display:flex;gap:8px;margin:24px 0}
.ob-dot{width:8px;height:8px;border-radius:50%;background:var(--ink3);transition:all .3s}
.ob-dot.active{width:24px;border-radius:4px;background:var(--accent)}
.ob-btn{padding:14px 48px;background:var(--accent);color:#fff;font-size:15px;font-weight:600;border-radius:50px;margin-top:8px}
.ob-skip{margin-top:12px;font-size:13px;color:var(--ink3)}

/* ===== APP SHELL ===== */
.app{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}

/* TOPBAR */
.topbar{height:var(--topbar-h);padding-top:var(--safe-top);display:grid;grid-template-columns:48px 1fr 48px;align-items:center;padding-left:12px;padding-right:12px;background:var(--bg);border-bottom:1px solid rgba(255,255,255,.06);z-index:100;flex-shrink:0;position:relative}
.tb-logo{font-family:var(--font-brand);font-size:22px;text-align:center;color:var(--accent)}
.tb-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;position:relative}
.tb-btn svg{width:22px;height:22px}
.dot-badge{position:absolute;top:6px;right:4px;width:16px;height:16px;background:var(--accent);border-radius:50%;font-size:9px;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}

/* SCREENS CONTAINER */
.screens{flex:1;position:relative;overflow:hidden}
.screen{position:absolute;inset:0;display:none;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.screen.active{display:flex}
.screen.sub-screen{z-index:50;background:var(--bg)}

/* BOTTOM NAV */
.bnav{height:var(--bnav-h);padding-bottom:var(--safe-bot);display:flex;align-items:center;justify-content:space-around;background:var(--bg);border-top:1px solid rgba(255,255,255,.06);z-index:100;flex-shrink:0;position:relative}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--ink3);transition:color .2s;padding:4px 0;position:relative}
.nav-btn svg{width:24px;height:24px;transition:all .2s}
.nav-btn span{font-size:10px;font-weight:500}
.nav-btn.active{color:var(--accent)}
.nav-btn.active svg{stroke:var(--accent);fill:var(--accent);fill-opacity:.15}
.nb-av{width:26px;height:26px;border-radius:50%;overflow:hidden;border:2px solid transparent;transition:border-color .2s}
.nb-av img{width:100%;height:100%;object-fit:cover}
.nav-btn.active .nb-av{border-color:var(--accent)}
.nb-badge{position:absolute;top:-4px;right:-6px;background:var(--accent);color:#fff;font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-style:normal}

/* ===== PULL TO REFRESH ===== */
.ptr-indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;height:0;overflow:hidden;transition:height .3s ease,opacity .3s ease;opacity:0;flex-shrink:0}
.ptr-indicator.pulling{opacity:1}
.ptr-indicator.refreshing{opacity:1;height:60px!important}
.ptr-spinner{width:24px;height:24px;border:3px solid var(--card3);border-top-color:var(--accent);border-radius:50%;margin-bottom:4px;transition:transform .3s}
.ptr-indicator.refreshing .ptr-spinner{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ptr-text{font-size:11px;color:var(--ink3)}

/* ===== FAB (CREATE POST) ===== */
.fab{position:absolute;bottom:calc(var(--bnav-h) + 16px + var(--safe-bot));right:16px;width:52px;height:52px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:90;box-shadow:0 4px 16px rgba(255,77,109,.4);transition:transform .2s,box-shadow .2s}
.fab:active{transform:scale(.9)}

/* ===== CREATE POST ===== */
.cp-body{flex:1;display:flex;flex-direction:column;padding:16px;overflow-y:auto}
.cp-user{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.cp-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}
.cp-textarea{flex:0 0 auto;min-height:120px;font-size:15px;line-height:1.5;resize:none;padding:0;color:var(--ink);background:transparent}
.cp-textarea::placeholder{color:var(--ink3)}
.cp-preview{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.cp-preview img{width:80px;height:80px;border-radius:8px;object-fit:cover}
.cp-toolbar{display:flex;gap:8px;padding:12px 0;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;overflow-x:auto}
.cp-tool{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--card2);border-radius:20px;font-size:12px;color:var(--ink2);white-space:nowrap;flex-shrink:0}
.cp-tool svg{width:18px;height:18px;flex-shrink:0}
.cp-post-btn{margin-left:auto;padding:8px 20px;background:var(--accent);color:#fff;border-radius:20px;font-size:13px;font-weight:600}
.cp-location-tag{padding:4px 0}
.cp-location-tag span{display:inline-block;padding:6px 12px;background:var(--accent-bg);color:var(--accent);border-radius:16px;font-size:12px;font-weight:500}

/* ===== STORIES ===== */
.stories{display:flex;gap:14px;padding:12px 16px;overflow-x:auto;flex-shrink:0;scrollbar-width:none}
.stories::-webkit-scrollbar{display:none}
.story-item{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}
.story-item span{font-size:11px;color:var(--ink2);max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}
.story-ring{width:60px;height:60px;border-radius:50%;padding:2px;display:flex;align-items:center;justify-content:center}
.story-ring img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:2px solid var(--bg)}
.story-ring.unseen{background:linear-gradient(135deg,var(--accent),#ff9a56,var(--accent2))}
.story-ring.seen{background:var(--ink3)}
.story-ring.none{background:var(--card3)}
.story-item.your-story{position:relative}
.st-plus{position:absolute;bottom:14px;right:0;width:18px;height:18px;background:var(--accent);border-radius:50%;border:2px solid var(--bg);font-size:12px;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;line-height:1}

/* ===== FEED CARDS (SWIPEABLE) ===== */
.feed-stack{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:4px 8px}
.swipe-card{position:absolute;width:calc(100% - 16px);height:calc(100% - 8px);background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.3);touch-action:none;display:flex;flex-direction:column;cursor:grab;user-select:none;-webkit-user-select:none;will-change:transform}
.swipe-card.behind{pointer-events:none}
.swipe-card.flyout{transition:transform .4s ease,opacity .4s ease;pointer-events:none}
.fc-header{display:flex;align-items:center;gap:10px;padding:8px 12px;flex-shrink:0}
.fc-av{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}
.fc-user{flex:1}
.fc-user strong{font-size:13px;display:block}
.fc-user small{font-size:11px;color:var(--ink2)}
.fc-follow{color:var(--accent);font-size:12px;font-weight:600;padding:4px 12px;border:1px solid var(--accent);border-radius:6px;transition:all .2s}
.fc-follow.following{color:var(--ink2);background:var(--card2)}
.fc-media{position:relative;width:100%;flex:1;min-height:0;overflow:hidden;background:var(--card2)}
.fc-media img,.fc-media video{width:100%;height:100%;object-fit:cover}
.fc-media .dbl-heart-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:60px;pointer-events:none;z-index:5;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}
.fc-media .dbl-heart-card.pop{animation:dblPop .8s ease forwards}
.fc-body{padding:8px 12px 10px;flex-shrink:0}
.fc-actions{display:flex;align-items:center;gap:2px;margin-bottom:4px}
.fc-act{display:flex;align-items:center;gap:4px;padding:5px 7px;border-radius:20px;font-size:12px;color:var(--ink2);transition:all .2s;cursor:pointer}
.fc-act:active{background:var(--accent-bg)}
.fc-act svg{width:18px;height:18px}
.fc-act.liked{color:var(--accent)}
.fc-act.liked svg{fill:var(--accent);stroke:var(--accent)}
.fc-act.saved svg{fill:var(--ink);stroke:var(--ink)}
.fc-save{margin-left:auto}
.fc-caption{font-size:12px;line-height:1.3}
.fc-caption strong{margin-right:6px}
/* ===== REELS (HORIZONTAL SLIDE) ===== */
.reels-viewport{position:absolute;inset:0;overflow:hidden;background:#000}
.reels-track{display:flex;height:100%;transition:transform .35s cubic-bezier(.4,0,.2,1);will-change:transform}
.reels-track.dragging{transition:none}
.reel-card{flex:0 0 100%;width:100%;height:100%;position:relative;overflow:hidden;background:#000}
.reel-card video,.reel-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.reel-overlay{position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(0,0,0,.6));pointer-events:none}
.reel-info{position:absolute;bottom:70px;left:14px;right:70px;z-index:2}
.reel-user{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.reel-user img{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #fff}
.reel-user strong{color:#fff;font-size:13px;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.reel-follow{color:#fff;font-size:11px;font-weight:600;border:1px solid rgba(255,255,255,.5);padding:3px 10px;border-radius:6px;background:rgba(255,255,255,.1);transition:all .2s}
.reel-follow.following{background:rgba(255,255,255,.25);border-color:transparent}
.reel-caption{color:#fff;font-size:13px;text-shadow:0 1px 4px rgba(0,0,0,.5);margin-bottom:8px}
.reel-music{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.7);font-size:11px}
.reel-music::before{content:"♫"}
.reel-sidebar{position:absolute;right:10px;bottom:80px;display:flex;flex-direction:column;align-items:center;gap:18px;z-index:2}
.reel-btn{display:flex;flex-direction:column;align-items:center;gap:2px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5);cursor:pointer}
.reel-btn svg{width:26px;height:26px;filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}
.reel-btn small{font-size:10px}
.reel-btn.liked svg{fill:var(--accent);stroke:var(--accent)}

/* Reel double-tap heart */
.reel-dbl-heart{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:80px;pointer-events:none;z-index:10;filter:drop-shadow(0 4px 16px rgba(0,0,0,.5))}
.reel-dbl-heart.pop{animation:dblPop .8s ease forwards}

/* Reel pause indicator */
.reel-pause-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;background:rgba(0,0,0,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:8;opacity:0;transition:opacity .2s;pointer-events:none}
.reel-pause-indicator.show{opacity:1}
.reel-pause-indicator svg{width:28px;height:28px;fill:#fff}

/* Reel indicators */
.reel-indicators{position:absolute;top:12px;left:50%;transform:translateX(-50%);display:flex;gap:4px;z-index:10;pointer-events:none}
.reel-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);transition:all .3s}
.reel-dot.active{background:#fff;width:18px;border-radius:3px}

/* ===== CHAT ===== */
.ch-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}
.chat-tab{flex:1;padding:14px;font-size:14px;font-weight:500;color:var(--ink3);border-bottom:2px solid transparent;transition:all .2s}
.chat-tab.active{color:var(--ink);border-color:var(--accent)}
.chat-panel{display:none;flex:1;flex-direction:column;overflow-y:auto}
.chat-panel.active{display:flex}
.dm-list{display:flex;flex-direction:column}
.dm-item{display:flex;align-items:center;gap:12px;padding:14px 16px;transition:background .2s}
.dm-item:active{background:var(--card2)}
.dm-item img{width:50px;height:50px;border-radius:50%;object-fit:cover;flex-shrink:0}
.dm-info{flex:1;min-width:0}
.dm-info strong{font-size:14px;display:block}
.dm-info p{font-size:12px;color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dm-time{font-size:11px;color:var(--ink3);flex-shrink:0}

/* Chat attach button */
.chat-attach-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;border-radius:50%;transition:background .2s}
.chat-attach-btn:active{background:var(--card2)}

/* Chat file message */
.chat-file-msg{background:var(--card2);border-radius:12px;padding:10px 14px;display:flex;align-items:center;gap:10px;max-width:75%;animation:msgIn .3s ease}
.chat-file-msg.sent{align-self:flex-end;background:var(--accent);color:#fff}
.chat-file-msg.received{align-self:flex-start}
.chat-file-icon{font-size:24px;flex-shrink:0}
.chat-file-info{flex:1;min-width:0}
.chat-file-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-file-size{font-size:10px;opacity:.7}

/* Shared post in chat */
.chat-shared-post{background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;max-width:75%;animation:msgIn .3s ease;cursor:pointer}
.chat-shared-post.sent{align-self:flex-end}
.chat-shared-post.received{align-self:flex-start}
.chat-shared-post img{width:100%;height:120px;object-fit:cover}
.chat-shared-post-info{padding:8px 10px}
.chat-shared-post-info strong{font-size:12px;display:block}
.chat-shared-post-info p{font-size:11px;color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* AI Chat */
.ai-area{flex:1;overflow-y:auto;padding:16px}
.ai-welcome{text-align:center;padding:40px 20px}
.ai-icon{font-size:48px;margin-bottom:8px}
.ai-welcome h3{font-size:20px;font-family:var(--font-brand);margin-bottom:6px}
.ai-welcome p{font-size:13px;color:var(--ink2);margin-bottom:20px}
.ai-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.ai-suggest{padding:8px 14px;background:var(--card2);border-radius:20px;font-size:12px;color:var(--ink);border:1px solid rgba(255,255,255,.06);transition:all .2s}
.ai-suggest:active{background:var(--accent-bg);border-color:var(--accent)}
.ai-bar{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;align-items:center}
.ai-bar input{flex:1;padding:10px 16px;background:var(--card2);border-radius:24px;font-size:14px}
.ai-bar button:last-child{width:40px;height:40px;background:var(--accent);border-radius:50%;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-msg{margin-bottom:12px;display:flex;gap:8px;animation:msgIn .3s ease}
.ai-msg.user{flex-direction:row-reverse}
.ai-msg .bubble{max-width:80%;padding:10px 14px;border-radius:16px;font-size:13px;line-height:1.5}
.ai-msg.user .bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.ai-msg.bot .bubble{background:var(--card2);border-bottom-left-radius:4px}
.ai-msg.bot .ai-av{width:28px;height:28px;background:var(--card2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
@keyframes msgIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.ai-card{background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;margin-top:8px;cursor:pointer}
.ai-card-title{font-size:13px;font-weight:600;padding:10px 10px 2px}
.ai-card-sub{font-size:11px;color:var(--ink2);padding:0 10px 6px}
.ai-card-action{display:block;width:100%;padding:8px;background:var(--accent);color:#fff;text-align:center;font-size:12px;font-weight:600}

/* ===== SHOP + EVENTS ===== */
.se-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}
.se-tab{flex:1;padding:12px;font-size:14px;font-weight:500;color:var(--ink3);border-bottom:2px solid transparent;transition:all .2s;text-align:center}
.se-tab.active{color:var(--ink);border-color:var(--accent)}
.cart-tab{flex:0;padding:12px 16px;font-size:14px}
.se-panel{display:none;flex:1;flex-direction:column;overflow:hidden;min-height:0}
.se-panel.active{display:flex}
.cat-pills{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;flex-shrink:0;scrollbar-width:none}
.cat-pills::-webkit-scrollbar{display:none}
.shop-cat{padding:8px 16px;background:var(--card2);border-radius:20px;font-size:12px;white-space:nowrap;transition:all .2s;flex-shrink:0;cursor:pointer}
.shop-cat.active{background:var(--accent);color:#fff}
/* Scroll containers for shop and events */
.shop-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;min-height:0;scrollbar-width:none}
.shop-scroll::-webkit-scrollbar{display:none}
.events-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;min-height:0;scrollbar-width:none}
.events-scroll::-webkit-scrollbar{display:none}
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:10px 12px 24px}
.product-card{background:var(--card);border-radius:var(--radius-sm);position:relative;transition:transform .2s;cursor:pointer;overflow:hidden}
.product-card:active{transform:scale(.98)}
.product-card img{width:100%;height:160px;object-fit:cover;display:block}
.product-card-body{padding:12px}
.product-badge{position:absolute;top:8px;left:8px;padding:3px 8px;border-radius:4px;font-size:9px;font-weight:700;color:#fff;text-transform:uppercase;background:var(--accent);z-index:2}
.product-card-body h5{font-size:13px;font-weight:600;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;color:var(--ink)}
.product-rating{font-size:11px;color:var(--gold);margin-bottom:4px}
.product-price{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.product-price .current{font-size:15px;font-weight:700;color:var(--accent)}
.product-price .original{font-size:11px;color:var(--ink3);text-decoration:line-through}
.product-price .discount{font-size:10px;color:var(--green);font-weight:600}
.add-cart-btn{width:100%;padding:10px;background:var(--accent);color:#fff;border-radius:8px;font-size:13px;font-weight:600;transition:transform .2s}
.add-cart-btn:active{transform:scale(.96)}

/* EVENTS */
.ev-list{display:flex;flex-direction:column;gap:14px;padding:12px 14px 24px}
.event-card{background:var(--card);border-radius:var(--radius);overflow:hidden;transition:transform .2s;cursor:pointer}
.event-card:active{transform:scale(.98)}
.event-card-img{width:100%;height:180px;object-fit:cover;display:block}
.event-card-body{padding:16px}
.event-card-body h4{font-size:17px;font-weight:700;margin-bottom:5px;color:var(--ink)}
.event-meta{font-size:13px;color:var(--ink2);margin-bottom:10px}
.event-meta span{display:block;margin-bottom:2px}
.event-tags{display:flex;gap:6px;margin-bottom:8px}
.event-tag{display:inline-block;padding:3px 10px;background:var(--accent-bg);color:var(--accent);border-radius:12px;font-size:10px;font-weight:600}
.event-footer{display:flex;align-items:center;justify-content:space-between}
.event-price{font-size:16px;font-weight:700;color:var(--accent)}
.event-book-btn{padding:8px 20px;background:var(--accent);color:#fff;border-radius:8px;font-size:13px;font-weight:600}

/* ===== PROFILE ===== */
.prof-head{padding:16px}
.prof-top{display:flex;align-items:center;gap:20px;margin-bottom:14px}
.prof-av{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);flex-shrink:0}
.prof-stats{display:flex;gap:20px;flex:1;justify-content:center}
.ps{text-align:center}
.ps.clickable{cursor:pointer;-webkit-tap-highlight-color:transparent}
.ps.clickable:active{opacity:.7}
.ps strong{font-size:16px;display:block;font-family:var(--font-brand)}
.ps small{font-size:11px;color:var(--ink2)}
.prof-bio h3{font-size:15px;margin-bottom:2px}
.vbadge{color:var(--accent);font-size:13px}
.breed{font-size:12px;color:var(--ink2);margin-bottom:4px}
.prof-bio>p:last-child{font-size:13px;color:var(--ink2);line-height:1.4}
.prof-btns{display:flex;gap:8px;margin-top:12px}
.pbtn{flex:1;padding:8px;background:var(--card2);border-radius:8px;font-size:13px;font-weight:600;text-align:center;cursor:pointer;transition:all .2s}
.pbtn:active{transform:scale(.97)}
.pbtn.primary{background:var(--accent);color:#fff}
.prof-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06)}
.prof-tab{flex:1;padding:12px;text-align:center;font-size:18px;color:var(--ink3);border-bottom:2px solid transparent;transition:all .2s;cursor:pointer}
.prof-tab.active{color:var(--ink);border-color:var(--ink)}
.prof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.prof-grid .pg{aspect-ratio:1;overflow:hidden;cursor:pointer;position:relative}
.prof-grid .pg:active{opacity:.8}
.prof-grid .pg img{width:100%;height:100%;object-fit:cover}

/* ===== EDIT PROFILE ===== */
.ep-body{padding:16px;overflow-y:auto;flex:1}
.ep-avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px}
.ep-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--accent)}
.ep-change-photo{color:var(--accent);font-size:13px;font-weight:600}
.ep-field{margin-bottom:16px}
.ep-field label{display:block;font-size:12px;color:var(--ink3);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.ep-input{width:100%;padding:12px;background:var(--card2);border-radius:8px;font-size:14px;color:var(--ink)}
.ep-textarea{min-height:80px;resize:none;line-height:1.5}

/* ===== FOLLOWERS / FOLLOWING LIST ===== */
.follow-list{padding:0;overflow-y:auto;flex:1}
.follow-item{display:flex;align-items:center;gap:12px;padding:12px 16px}
.follow-item img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}
.follow-item-info{flex:1;min-width:0}
.follow-item-info strong{font-size:14px;display:block}
.follow-item-info span{font-size:12px;color:var(--ink2)}
.follow-btn{padding:6px 20px;border-radius:8px;font-size:12px;font-weight:600;flex-shrink:0;transition:all .2s}
.follow-btn.following{background:var(--card2);color:var(--ink)}
.follow-btn.not-following{background:var(--accent);color:#fff}

/* ===== EXPLORE POST DETAIL ===== */
.exp-post-body{flex:1;overflow-y:auto}
.exp-post-img{width:100%;max-height:400px;object-fit:cover}
.exp-post-header{display:flex;align-items:center;gap:10px;padding:12px 16px}
.exp-post-header img{width:36px;height:36px;border-radius:50%;object-fit:cover}
.exp-post-header strong{font-size:14px}
.exp-post-header small{font-size:11px;color:var(--ink2);margin-left:auto}
.exp-post-actions{display:flex;align-items:center;gap:2px;padding:4px 12px}
.exp-post-caption{padding:4px 16px 16px;font-size:13px;line-height:1.4}
.exp-post-caption strong{margin-right:6px}

/* ===== SUB SCREENS ===== */
.sub-top{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}
.back-btn{font-size:28px;width:36px;height:36px;display:flex;align-items:center;justify-content:center}
.sub-top h2{font-size:17px;font-weight:600;flex:1}
.sub-search{flex:1;padding:8px 14px;background:var(--card2);border-radius:10px;font-size:14px}
.sub-av{width:32px;height:32px;border-radius:50%;object-fit:cover}
.cart-link{margin-left:auto;font-size:14px;position:relative}
.cart-link .cart-badge{font-size:10px;background:var(--accent);color:#fff;border-radius:50%;padding:1px 5px;margin-left:2px}

/* SEARCH */
.search-body{padding:16px;overflow-y:auto;flex:1}
.search-body h4{font-size:14px;color:var(--ink2);margin-bottom:10px}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.tags span{padding:6px 14px;background:var(--card2);border-radius:16px;font-size:12px;color:var(--accent)}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.exp-item{aspect-ratio:1;position:relative;overflow:hidden;cursor:pointer}
.exp-item.big{grid-column:span 2;grid-row:span 2}
.exp-item img{width:100%;height:100%;object-fit:cover;transition:transform .2s}
.exp-item:active img{transform:scale(1.03)}
.exp-likes{position:absolute;bottom:6px;left:6px;font-size:11px;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);background:rgba(0,0,0,.3);padding:2px 6px;border-radius:4px}
.exp-hover{position:absolute;inset:0;background:rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;gap:4px;color:#fff;font-size:14px;font-weight:600;opacity:0;transition:opacity .2s}
.exp-item:active .exp-hover{opacity:1}
.search-account{display:flex;align-items:center;gap:10px;padding:10px 0;cursor:pointer}
.search-account img{width:40px;height:40px;border-radius:50%;object-fit:cover}
.search-account-info{flex:1}
.search-account-info strong{font-size:14px;display:block}
.search-account-info span{font-size:12px;color:var(--ink2)}

/* NOTIFS */
.notif-body{padding:0 16px;overflow-y:auto;flex:1}
.notif-body h4{font-size:12px;color:var(--ink3);text-transform:uppercase;letter-spacing:1px;padding:14px 0 8px}
.nf{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.nf img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.nf-icon{width:40px;height:40px;border-radius:50%;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.nf div{flex:1;font-size:13px;line-height:1.4}
.nf small{display:block;color:var(--ink3);font-size:11px;margin-top:2px}
.nf-follow{padding:6px 16px;background:var(--accent);color:#fff;border-radius:8px;font-size:12px;font-weight:600;flex-shrink:0}

/* SETTINGS */
.set-body{padding:16px;overflow-y:auto;flex:1}
.set-group{margin-bottom:20px}
.set-group h4{font-size:12px;color:var(--ink3);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.set-item{padding:14px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.set-item:active{color:var(--accent)}
.theme-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.theme-row span{font-size:14px}
.theme-btns{display:flex;gap:4px;background:var(--card2);border-radius:8px;padding:3px}
.theme-opt{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;transition:all .2s}
.theme-opt.active{background:var(--accent);color:#fff}
.logout{width:100%;padding:14px;background:var(--card2);color:var(--accent);border-radius:10px;font-size:14px;font-weight:600;margin-top:20px}
.set-footer{text-align:center;font-size:11px;color:var(--ink3);margin-top:16px}

/* DM CHAT */
.msg-area{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}
.chat-msg{max-width:75%;padding:10px 14px;border-radius:16px;font-size:13px;line-height:1.4;animation:msgIn .3s ease}
.chat-msg.sent{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.chat-msg.received{align-self:flex-start;background:var(--card2);border-bottom-left-radius:4px}
.msg-bar{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;align-items:center}
.msg-bar input{flex:1;padding:10px 16px;background:var(--card2);border-radius:24px;font-size:14px}
.msg-bar button:last-child{width:40px;height:40px;background:var(--accent);border-radius:50%;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* CART */
.cart-body{flex:1;overflow-y:auto;padding:16px}
.cart-empty{text-align:center;padding:60px 20px}
.cart-empty-icon{font-size:48px;margin-bottom:8px}
.cart-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.cart-item img{width:70px;height:70px;border-radius:8px;object-fit:cover}
.cart-item-info{flex:1}
.cart-item-info h5{font-size:13px;margin-bottom:4px}
.cart-price{font-size:15px;color:var(--accent);font-weight:700}
.cart-qty{display:flex;align-items:center;gap:10px;margin-top:6px}
.cart-qty button{width:28px;height:28px;background:var(--card2);border-radius:6px;font-size:16px;display:flex;align-items:center;justify-content:center}
.cart-qty span{font-size:14px;font-weight:600;min-width:20px;text-align:center}
.cart-remove{color:var(--accent);font-size:12px;margin-top:4px}
.cart-summary{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}
.cart-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;color:var(--ink2)}
.cart-row.total{font-size:16px;color:var(--ink);font-weight:700;border-top:1px solid rgba(255,255,255,.06);padding-top:10px;margin-top:6px}
.cart-checkout-btn{width:100%;padding:14px;background:var(--accent);color:#fff;border-radius:10px;font-size:15px;font-weight:600;margin-top:12px}

/* CHECKOUT */
.co-body{padding:16px;overflow-y:auto;flex:1}
.checkout-section{margin-bottom:20px}
.checkout-section h4{font-size:14px;margin-bottom:10px}
.checkout-input{width:100%;padding:12px;background:var(--card2);border-radius:8px;font-size:14px;margin-bottom:8px;display:block}
.checkout-row{display:flex;gap:8px}
.checkout-row .checkout-input{flex:1}
.payment-options{display:flex;flex-direction:column;gap:8px}
.payment-opt{display:flex;align-items:center;gap:12px;padding:14px;background:var(--card2);border-radius:10px;font-size:14px;border:2px solid transparent;transition:all .2s;cursor:pointer}
.payment-opt.selected{border-color:var(--accent);background:var(--accent-bg)}
.payment-opt-icon{font-size:20px}
.checkout-total{display:flex;justify-content:space-between;font-size:18px;font-weight:700;padding:16px 0;border-top:1px solid rgba(255,255,255,.06);margin-top:8px}
.place-order-btn{width:100%;padding:16px;background:var(--accent);color:#fff;border-radius:10px;font-size:16px;font-weight:600}

/* PRODUCT DETAIL */
.pd-body{padding:0;overflow-y:auto;flex:1}
.pd-img{width:100%;height:280px;object-fit:cover}
.pd-title{font-size:18px;padding:16px 16px 4px}
.pd-price-row{display:flex;align-items:center;gap:8px;padding:0 16px;margin-bottom:4px}
.pd-current{font-size:22px;font-weight:700;color:var(--accent)}
.pd-original{font-size:14px;color:var(--ink3);text-decoration:line-through}
.pd-discount{font-size:12px;color:var(--green);font-weight:600}
.pd-rating{font-size:13px;color:var(--gold);padding:0 16px;margin-bottom:8px}
.pd-desc{font-size:13px;color:var(--ink2);padding:0 16px;line-height:1.5;margin-bottom:12px}
.pd-specs{padding:0 16px;margin-bottom:16px}
.pd-spec{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:13px}
.pd-spec-label{color:var(--ink2)}
.pd-add-cart{width:calc(100% - 32px);margin:0 16px 8px;padding:14px;background:var(--accent);color:#fff;border-radius:10px;font-size:15px;font-weight:600}
.pd-buy-now{width:calc(100% - 32px);margin:0 16px 20px;padding:14px;background:var(--card2);color:var(--ink);border-radius:10px;font-size:15px;font-weight:600}

/* EVENT DETAIL */
.ed-body{padding:0;overflow-y:auto;flex:1}
.ed-img{width:100%;height:220px;object-fit:cover}
.ed-title{font-size:20px;padding:16px 16px 8px}
.ed-meta{padding:0 16px;margin-bottom:12px}
.ed-meta span{display:block;font-size:13px;color:var(--ink2);margin-bottom:4px}
.ed-desc{font-size:13px;color:var(--ink2);padding:0 16px;line-height:1.5;margin-bottom:16px}
.ed-book-btn{width:calc(100% - 32px);margin:0 16px 20px;padding:14px;background:var(--accent);color:#fff;border-radius:10px;font-size:15px;font-weight:600}

/* VET */
.vet-body{padding:16px;overflow-y:auto;flex:1}
.vet-card{background:var(--card);border-radius:var(--radius);padding:16px;margin-bottom:12px}
.vet-card h4{font-size:15px;margin-bottom:4px}
.vet-card>p{font-size:12px;color:var(--ink2);margin-bottom:6px}
.vet-stars{color:var(--gold);font-size:13px;margin-bottom:8px}
.vet-stars small{color:var(--ink3)}
.vet-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.vet-tags span{padding:4px 10px;background:var(--accent-bg);color:var(--accent);border-radius:12px;font-size:10px;font-weight:600}
.vet-acts{display:flex;gap:8px}
.vet-acts button{flex:1;padding:8px;background:var(--card2);border-radius:8px;font-size:12px;font-weight:500}

/* ===== STORY VIEWER ===== */
.sv{position:absolute;inset:0;z-index:200;background:#000;display:flex;flex-direction:column}
.sv-bars{display:flex;gap:3px;padding:8px 10px 0;position:absolute;top:0;left:0;right:0;z-index:5}
.sv-bar{flex:1;height:2px;background:rgba(255,255,255,.3);border-radius:2px;overflow:hidden}
.sv-bar .sv-bar-fill{height:100%;background:#fff;width:0;transition:width .05s linear}
.sv-bar.done .sv-bar-fill{width:100%}
.sv-head{display:flex;align-items:center;gap:8px;padding:20px 14px 8px;position:absolute;top:0;left:0;right:0;z-index:5}
.sv-av{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #fff}
#svUser{color:#fff;font-size:13px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.sv-time{color:rgba(255,255,255,.6);font-size:11px}
.sv-x{margin-left:auto;color:#fff;font-size:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center}
.sv-img{flex:1;width:100%;object-fit:cover}
.sv-left,.sv-right{position:absolute;top:60px;bottom:0;width:40%;z-index:4}
.sv-left{left:0}
.sv-right{right:0}

/* ===== BOTTOM SHEETS ===== */
.overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:150;animation:fadeIn .2s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.bsheet{position:absolute;bottom:0;left:0;right:0;background:var(--card);border-radius:16px 16px 0 0;z-index:160;max-height:70%;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s ease}
.bsheet.open{transform:translateY(0)}
.bs-handle{width:36px;height:4px;background:var(--ink3);border-radius:2px;margin:10px auto}
.bsheet h4{text-align:center;padding:0 16px 10px;font-size:15px;border-bottom:1px solid rgba(255,255,255,.06)}
.bs-list{flex:1;overflow-y:auto;padding:12px 16px}
.cmt{display:flex;gap:10px;margin-bottom:14px}
.cmt img{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}
.cmt div{font-size:13px;line-height:1.4}
.cmt strong{margin-right:6px}
.cmt small{display:block;color:var(--ink3);font-size:11px;margin-top:2px}
.bs-input{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}
.bs-input input{flex:1;padding:10px 14px;background:var(--card2);border-radius:20px;font-size:13px}
.bs-input button{padding:10px 16px;background:var(--accent);color:#fff;border-radius:20px;font-size:13px;font-weight:600}

/* SHARE SHEET — send to users */
.share-users{display:flex;gap:12px;padding:14px 16px;overflow-x:auto;scrollbar-width:none}
.share-users::-webkit-scrollbar{display:none}
.sh-user{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;cursor:pointer;transition:transform .2s}
.sh-user:active{transform:scale(.95)}
.sh-user img{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid transparent;transition:border-color .2s}
.sh-user.selected img{border-color:var(--accent)}
.sh-user span{font-size:10px;color:var(--ink2);max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}
.share-divider{height:1px;background:rgba(255,255,255,.06);margin:0 16px}

/* SHARE GRID */
.share-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px}
.sh-opt{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:11px;color:var(--ink2)}
.sh-opt span{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px}

/* REPOST SHEET */
.rp-opts{padding:16px}
.rp-opt{width:100%;padding:14px;background:var(--card2);border-radius:10px;font-size:14px;margin-bottom:8px;text-align:left;transition:background .2s}
.rp-opt:active{background:var(--accent-bg)}

/* FILE ATTACH SHEET */
.file-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px}
.file-opt{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;background:var(--card2);border-radius:12px;font-size:12px;color:var(--ink2);transition:all .2s}
.file-opt:active{background:var(--accent-bg);color:var(--accent)}
.file-opt span{font-size:28px}

/* DOUBLE TAP HEART */
.dbl-heart{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:80px;z-index:300;pointer-events:none;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}
.dbl-heart.show{animation:dblPop .8s ease forwards}
@keyframes dblPop{0%{transform:translate(-50%,-50%) scale(0);opacity:1}15%{transform:translate(-50%,-50%) scale(1.3)}30%{transform:translate(-50%,-50%) scale(1)}80%{opacity:1}100%{transform:translate(-50%,-50%) scale(1);opacity:0}}

/* TOAST */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--card);color:var(--ink);padding:12px 24px;border-radius:24px;font-size:13px;font-weight:500;box-shadow:0 4px 20px rgba(0,0,0,.3);z-index:400;animation:toastIn .3s ease}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ===== REELS NAV DARK ===== */
.bnav.reels-mode{background:transparent;border-top:none;position:absolute;bottom:0;left:0;right:0}
.bnav.reels-mode .nav-btn{color:rgba(255,255,255,.5)}
.bnav.reels-mode .nav-btn.active{color:#fff}
.bnav.reels-mode .nav-btn.active svg{stroke:#fff;fill:#fff;fill-opacity:.15}

/* ===== DESKTOP FRAME ===== */
@media(hover:hover) and (min-width:500px){
  body{display:flex;align-items:center;justify-content:center;background:#111;min-height:100vh}
  .landing{max-width:400px;max-height:min(860px,92vh);border-radius:32px;overflow:hidden;position:relative;box-shadow:0 0 60px rgba(0,0,0,.5)}
  .onboarding{max-width:400px;max-height:min(860px,92vh);border-radius:32px;overflow:hidden;position:relative}
  .app{max-width:400px;max-height:min(860px,92vh);border-radius:32px;overflow:hidden;position:relative;box-shadow:0 0 60px rgba(0,0,0,.5)}
  .dbl-heart{position:absolute}
  .exp-item:hover .exp-hover{opacity:1}
  .exp-item:hover img{transform:scale(1.03)}
}


/* ===== PHONE MOCKUP (Reels section) ===== */
.wf-phone-mockup {
  width: 240px; height: 480px;
  background: #1B1612; border-radius: 32px;
  padding: 8px; position: relative;
  box-shadow: 0 20px 60px rgba(0,0,0,.4), inset 0 0 0 1px rgba(255,255,255,.1);
}
.wf-phone-notch {
  position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
  width: 80px; height: 22px; background: #1B1612; border-radius: 0 0 14px 14px; z-index: 5;
}
.wf-phone-screen {
  width: 100%; height: 100%; border-radius: 24px; overflow: hidden; position: relative;
  background: #000;
}
.wf-phone-video {
  width: 100%; height: 100%; object-fit: cover;
}
.wf-reel-ui {
  position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end;
  padding: 16px 12px; background: linear-gradient(transparent 50%, rgba(0,0,0,.6));
  pointer-events: none;
}
.wf-reel-sidebar {
  position: absolute; right: 10px; bottom: 100px;
  display: flex; flex-direction: column; gap: 16px; align-items: center;
}
.wf-reel-action { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.wf-reel-action span { font-size: 10px; color: #fff; font-weight: 500; }
.wf-reel-bottom { color: #fff; }
.wf-reel-user { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.wf-reel-av { width: 28px; height: 28px; border-radius: 50%; background: rgba(255,255,255,.2); }
.wf-reel-user strong { font-size: 12px; }
.wf-reel-follow-btn {
  font-size: 10px; padding: 3px 10px; border: 1px solid #fff; border-radius: 4px; margin-left: 6px;
}
.wf-reel-bottom p { font-size: 11px; opacity: .85; }

/* ===== MINI PHONE MOCKUP (Features bento) ===== */
.wf-bc-phone-mini { display: flex; justify-content: center; padding: 16px 0 8px; }
.wf-mini-phone {
  width: 120px; height: 200px;
  background: #1B1612; border-radius: 18px;
  padding: 4px; position: relative;
  box-shadow: 0 8px 30px rgba(0,0,0,.2);
}
.wf-mini-notch {
  position: absolute; top: 4px; left: 50%; transform: translateX(-50%);
  width: 40px; height: 10px; background: #1B1612; border-radius: 0 0 8px 8px; z-index: 5;
}
.wf-mini-screen {
  width: 100%; height: 100%; border-radius: 14px; overflow: hidden; position: relative;
}
.wf-mini-img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  transition: opacity .6s ease;
}
.wf-mini-img-2 { opacity: 0; animation: wfMiniSwipe 4s ease-in-out infinite; }
@keyframes wfMiniSwipe {
  0%, 40% { opacity: 0; transform: translateX(0); }
  50%, 90% { opacity: 1; transform: translateX(0); }
  100% { opacity: 0; }
}
.wf-mini-heart {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0);
  font-size: 32px; color: #ff4d6d; z-index: 10;
  animation: wfMiniHeart 4s ease-in-out infinite;
}
@keyframes wfMiniHeart {
  0%, 44% { transform: translate(-50%, -50%) scale(0); opacity: 0; }
  48% { transform: translate(-50%, -50%) scale(1.2); opacity: 1; }
  52% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
  60%, 100% { transform: translate(-50%, -50%) scale(0); opacity: 0; }
}

/* ===== LOST & FOUND — LANDING PAGE ===== */
.wf-lf-sec {
  padding: 80px 24px 40px; position: relative; z-index: 2;
  background: linear-gradient(180deg, var(--wf-cream) 0%, #FFF5EB 100%);
}
.wf-lf-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start;
}
.wf-lf-sec h2 {
  font-family: 'Playfair Display', serif; font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800; line-height: 1.15; margin-bottom: 16px;
}
.wf-lf-sec p { font-size: .95rem; line-height: 1.65; color: var(--wf-bark); opacity: .65; }
.wf-lf-stats {
  display: flex; gap: 24px; margin: 24px 0; flex-wrap: wrap;
}
.wf-lf-stat { text-align: center; }
.wf-lf-stat strong {
  display: block; font-family: 'Playfair Display', serif; font-size: 1.6rem;
  color: var(--wf-terra); font-weight: 700;
}
.wf-lf-stat span { font-size: .8rem; color: var(--wf-bark); opacity: .5; }
.wf-lf-steps { display: flex; flex-direction: column; gap: 16px; margin-top: 24px; }
.wf-lf-step {
  display: flex; align-items: flex-start; gap: 14px;
}
.wf-lf-step-num {
  width: 32px; height: 32px; flex-shrink: 0;
  background: var(--wf-terra); color: #fff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; font-weight: 700;
}
.wf-lf-step strong { font-size: .9rem; display: block; margin-bottom: 2px; color: var(--wf-bark); }
.wf-lf-step p { font-size: .82rem; margin: 0; opacity: .55; }

/* L&F Cards */
.wf-lf-cards {
  display: flex; flex-direction: column; gap: 16px;
}
.wf-lf-card {
  background: #fff; border-radius: 16px; overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
  display: grid; grid-template-columns: 90px 1fr; position: relative;
  transition: transform .3s ease;
}
.wf-lf-card:hover { transform: translateY(-2px); }
.wf-lf-card img { width: 90px; height: 90px; object-fit: cover; }
.wf-lf-card-info {
  padding: 10px 12px; display: flex; flex-direction: column; justify-content: center;
}
.wf-lf-card-info strong { font-size: .9rem; color: var(--wf-bark); }
.wf-lf-card-info span { font-size: .75rem; color: var(--wf-bark); opacity: .5; }
.wf-lf-loc { font-size: .72rem !important; margin-top: 2px; }
.wf-lf-badge {
  position: absolute; top: 8px; right: 8px;
  padding: 3px 10px; border-radius: 20px;
  font-size: .65rem; font-weight: 700; letter-spacing: .5px;
}
.wf-lf-badge-lost { background: #ff4d6d; color: #fff; }
.wf-lf-badge-found { background: #3498db; color: #fff; }
.wf-lf-badge-reunited { background: #2ecc71; color: #fff; }

/* Searching dog SVG animation */
.wf-search-dog {
  width: 100px; margin: 16px auto 0; display: block;
}
.wf-sd-head { animation: wfSniff 1.5s ease-in-out infinite; transform-origin: 28px 52px; }
@keyframes wfSniff {
  0%, 100% { transform: rotate(0deg); }
  30% { transform: rotate(8deg); }
  60% { transform: rotate(-5deg); }
}
.wf-sd-sniff { animation: wfSniffLines 1s ease-in-out infinite; }
@keyframes wfSniffLines {
  0%, 100% { opacity: 1; transform: translateX(0); }
  50% { opacity: .3; transform: translateX(-3px); }
}
.wf-sd-tail { animation: wfTailWag2 .4s ease-in-out infinite alternate; transform-origin: 85px 55px; }
@keyframes wfTailWag2 { 0% { transform: rotate(-10deg); } 100% { transform: rotate(15deg); } }
.wf-sd-ear { animation: wfEarFlop .8s ease-in-out infinite alternate; transform-origin: 38px 40px; }
@keyframes wfEarFlop { 0% { transform: rotate(0); } 100% { transform: rotate(-8deg); } }

/* L&F Reunion banner */
.wf-lf-reunion {
  max-width: 1100px; margin: 40px auto 0; border-radius: 20px; overflow: hidden;
  position: relative; height: 280px;
}
.wf-lf-reunion-img { width: 100%; height: 100%; object-fit: cover; }
.wf-lf-reunion-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(transparent 30%, rgba(27,22,18,.7));
  display: flex; flex-direction: column; justify-content: flex-end; padding: 24px 32px;
}
.wf-lf-reunion-quote {
  font-family: 'Playfair Display', serif; font-style: italic;
  font-size: 1.15rem; color: #fff; line-height: 1.5; opacity: 1 !important;
}
.wf-lf-reunion-overlay span { font-size: .85rem; color: rgba(255,255,255,.7); margin-top: 4px; }

/* ===== LOST & FOUND — APP SCREEN ===== */
/* Emergency Banner */
.lf-emergency-banner {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; margin: 8px 12px;
  background: linear-gradient(135deg, rgba(255,77,109,.12), rgba(255,77,109,.06));
  border: 1px solid rgba(255,77,109,.2);
  border-radius: 14px;
  flex-shrink: 0;
  max-height: 80px; overflow: hidden;
  transition: max-height .35s ease, opacity .3s ease, margin .35s ease, padding .35s ease;
  opacity: 1;
}
.lf-emergency-banner.lf-banner-hidden {
  max-height: 0; opacity: 0; margin-top: 0; margin-bottom: 0; padding-top: 0; padding-bottom: 0;
}
.lf-emergency-icon { font-size: 24px; flex-shrink: 0; }
.lf-emergency-text { flex: 1; }
.lf-emergency-text strong { display: block; font-size: 13px; color: var(--accent); }
.lf-emergency-text span { font-size: 11px; color: var(--ink2); line-height: 1.3; }
.lf-emergency-btn {
  padding: 8px 16px; background: var(--accent); color: #fff;
  border-radius: 20px; font-size: 12px; font-weight: 700;
  white-space: nowrap; flex-shrink: 0;
  animation: lf-pulse 2s infinite;
}
@keyframes lf-pulse { 0%,100%{box-shadow:0 0 0 0 rgba(255,77,109,.4)} 50%{box-shadow:0 0 0 8px rgba(255,77,109,0)} }
/* Search Bar */
.lf-search-bar {
  display: flex; align-items: center; gap: 8px;
  margin: 4px 12px 0; padding: 10px 14px;
  background: var(--card2); border-radius: 10px;
  border: 1px solid var(--border-subtle);
}
.lf-search-input {
  flex: 1; font-size: 13px; background: none; border: none;
  color: var(--ink); outline: none;
}
.lf-search-input::placeholder { color: var(--ink3); }
/* Stats Bar */
.lf-stats-bar {
  display: flex; gap: 4px; padding: 6px 12px;
}
.lf-stat-mini {
  flex: 1; text-align: center; padding: 8px 4px;
  background: var(--card2); border-radius: 8px;
}
.lf-stat-mini strong { display: block; font-size: 14px; color: var(--accent); font-weight: 700; }
.lf-stat-mini span { font-size: 10px; color: var(--ink3); }
/* Filter Tabs */
.lf-report-btn {
  padding: 6px 14px; background: var(--accent); color: #fff;
  border-radius: 20px; font-size: 12px; font-weight: 600;
}
.lf-tabs {
  display: flex; gap: 4px; padding: 8px 12px; overflow-x: auto;
  scrollbar-width: none; flex-shrink: 0;
}
.lf-tabs::-webkit-scrollbar { display: none; }
.lf-tab {
  padding: 7px 14px; border-radius: 20px; font-size: 12px; font-weight: 500;
  background: var(--card2); color: var(--ink2); white-space: nowrap;
  transition: all .2s; display: flex; align-items: center; gap: 4px;
}
.lf-tab-icon { font-size: 10px; }
.lf-tab.active { background: var(--accent); color: #fff; }
/* Feed */
.lf-feed { flex: 1; overflow-y: auto; padding: 8px 12px 80px; display: flex; flex-direction: column; gap: 14px; min-height: 0; }
.lf-empty { text-align: center; padding: 60px 20px; color: var(--ink3); }
.lf-empty-icon { font-size: 48px; margin-bottom: 12px; }
/* Cards — event-card style */
.lf-card {
  background: var(--card); border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--shadow-card); transition: transform .2s; cursor: pointer;
  flex-shrink: 0;
}
.lf-card:active { transform: scale(.98); }
.lf-card-img-wrap { position: relative; }
.lf-card-img { width: 100%; height: 210px; object-fit: cover; object-position: center top; display: block; flex-shrink: 0; }
.lf-card-badge {
  position: absolute; top: 10px; left: 10px;
  padding: 4px 10px; border-radius: 20px;
  font-size: 10px; font-weight: 700; letter-spacing: .4px;
}
.lf-card-badge.lost { background: #ff4d6d; color: #fff; }
.lf-card-badge.found { background: #3498db; color: #fff; }
.lf-card-badge.reunited { background: #2ecc71; color: #fff; }
.lf-card-time-badge {
  position: absolute; top: 10px; right: 10px;
  padding: 3px 9px; border-radius: 20px;
  font-size: 10px; font-weight: 600; background: rgba(0,0,0,.55); color: #fff;
}
.lf-card-body { padding: 12px 14px 14px; }
.lf-card-name { font-size: 16px; font-weight: 700; margin-bottom: 3px; color: var(--ink); }
.lf-card-meta { font-size: 12px; color: var(--ink2); font-weight: 500; }
.lf-card-location {
  display: flex; align-items: center; gap: 5px;
  font-size: 12px; color: var(--ink2); margin: 6px 0 8px;
}
.lf-card-location svg { flex-shrink: 0; color: var(--ink3); }
.lf-card-desc { font-size: 13px; color: var(--ink2); line-height: 1.5; margin-bottom: 12px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.lf-card-actions { display: flex; gap: 8px; align-items: center; }
.lf-card-contact {
  flex: 1; padding: 11px 14px; background: var(--accent); color: #fff;
  border-radius: 10px; font-size: 13px; font-weight: 600; text-align: center;
}
.lf-reunited-btn { background: #2ecc71 !important; color: #fff !important; }
.lf-card-save {
  padding: 9px 12px; background: var(--card2); border-radius: 8px;
  color: var(--ink3); transition: color .2s;
}
.lf-card-save.saved { color: var(--accent); }
.lf-card-save.saved svg { fill: var(--accent); }

/* L&F Report Form */
.lf-report-form { padding: 16px; display: flex; flex-direction: column; gap: 12px; overflow-y: auto; flex: 1; }
.lf-type-toggle { display: flex; gap: 4px; background: var(--card2); border-radius: 10px; padding: 3px; }
.lf-type-btn {
  flex: 1; padding: 10px; border-radius: 8px; font-size: 13px; font-weight: 600;
  text-align: center; color: var(--ink2); transition: all .2s;
}
.lf-type-btn.active { background: var(--accent); color: #fff; }
.lf-photo-upload {
  width: 100%; height: 160px; border: 2px dashed var(--card3);
  border-radius: var(--radius); display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px; cursor: pointer;
  transition: border-color .2s;
}
.lf-photo-upload:hover { border-color: var(--accent); }
.lf-photo-upload span { font-size: 13px; color: var(--ink3); }
.lf-input, .lf-select, .lf-textarea {
  width: 100%; padding: 12px 14px; background: var(--card2); border: 1px solid var(--card3);
  border-radius: 10px; font-size: 14px; color: var(--ink); transition: border-color .2s;
}
.lf-input:focus, .lf-select:focus, .lf-textarea:focus { border-color: var(--accent); }
.lf-textarea { min-height: 80px; resize: vertical; }
.lf-row { display: flex; gap: 10px; }
.lf-row > * { flex: 1; }
.lf-select { appearance: none; -webkit-appearance: none; }

/* ===== RESPONSIVE L&F ===== */
@media (max-width: 768px) {
  .wf-lf-inner { grid-template-columns: 1fr; gap: 32px; }
  .wf-lf-reunion { height: 200px; margin-left: 24px; margin-right: 24px; }
  .wf-lf-reunion-quote { font-size: .95rem; }
}


/* ===== L&F PANEL TOP (inside Shop screen) ===== */
.lf-panel-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 16px; gap: 8px;
}
.lf-panel-top .lf-tabs { padding: 0; flex: 1; }
.lf-panel-top .lf-report-btn { flex-shrink: 0; }

/* ===== L&F LIGHTBOX ===== */
.lf-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.92);
  display: flex; flex-direction: column;
  align-items: center; justify-content: flex-end;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.lf-lightbox.open { opacity: 1; pointer-events: auto; }
.lf-lightbox-inner {
  width: 100%; max-width: 480px;
  background: var(--bg); border-radius: 20px 20px 0 0;
  transform: translateY(40px); transition: transform .3s ease;
  overflow: hidden; max-height: 92vh; overflow-y: auto;
}
.lf-lightbox.open .lf-lightbox-inner { transform: translateY(0); }
.lf-lightbox-img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.lf-lightbox-body { padding: 20px; }
.lf-lightbox-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.lf-lightbox-name { font-size: 22px; font-weight: 700; font-family: var(--font-brand); }
.lf-lightbox-close { width: 36px; height: 36px; border-radius: 50%; background: var(--card2); color: var(--ink); display: flex; align-items: center; justify-content: center; font-size: 18px; cursor: pointer; flex-shrink: 0; }
.lf-lightbox-badge { display: inline-block; padding: 5px 14px; border-radius: 20px; font-size: 12px; font-weight: 700; letter-spacing: .5px; margin-bottom: 14px; }
.lf-lightbox-badge.lost { background: rgba(255,77,109,.15); color: #ff4d6d; }
.lf-lightbox-badge.found { background: rgba(52,152,219,.15); color: #3498db; }
.lf-lightbox-badge.reunited { background: rgba(46,204,113,.15); color: #2ecc71; }
.lf-lightbox-details { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.lf-lightbox-detail { display: flex; align-items: center; gap: 8px; font-size: 14px; color: var(--ink2); }
.lf-lightbox-desc { font-size: 14px; color: var(--ink2); line-height: 1.6; margin-bottom: 20px; padding: 14px; background: var(--card2); border-radius: 12px; }
.lf-lightbox-actions { display: flex; gap: 10px; padding-bottom: 20px; }
.lf-lightbox-contact { flex: 1; padding: 14px; background: var(--accent); color: #fff; border-radius: 12px; font-size: 15px; font-weight: 600; text-align: center; display: flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer; }
.lf-lightbox-share { padding: 14px 18px; background: var(--card2); color: var(--ink); border-radius: 12px; font-size: 14px; font-weight: 500; display: flex; align-items: center; gap: 6px; cursor: pointer; }
.lf-card { cursor: pointer; }
