@import url('https://fonts.googleapis.com/css2?family=Comic+Neue:wght@400;700&display=swap');

:root {
  --cream: #FFFDF5;
  --paper: #F5F0E8;
  --dark: #2C2606;
  --mid: #5a4e1a;
  --muted: #7a6e3a;
  --pastel-pink: #FFB3D9;
  --pastel-lime: #D4F73B;
  --pastel-lavender: #C9AAEE;
  --pastel-cyan: #A0EEE0;
  --pastel-purple: #B8A0EE;
  --hot-pink-dark: #99004f;
  --coral-dark: #8a2a22;
  --purple-dark: #3a1f88;
  --cyan-dark: #0a6e5a;
  --chartreuse-dark: #4a5a00;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  background-color: var(--cream);
  background-image: url('/clouds.svg');
  background-repeat: no-repeat;
  background-size: cover;
  background-attachment: fixed;
  font-family: 'Comic Neue', 'Comic Sans MS', cursive;
  color: var(--dark);
  min-height: 100vh;
  padding: 10px;
}

/* MARQUEE */
.marquee-bar {
  background: var(--pastel-pink);
  color: var(--hot-pink-dark);
  font-size: 13px;
  font-weight: 700;
  padding: 5px 0;
  white-space: nowrap;
  overflow: hidden;
  border-top: 3px solid var(--pastel-lime);
  border-bottom: 3px solid var(--pastel-lime);
  margin-bottom: 10px;
}
.marquee-inner {
  display: inline-block;
  animation: marquee 20s linear infinite;
  padding-left: 100%;
}
@keyframes marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

/* MASTHEAD */
.masthead {
  background: var(--pastel-lime);
  padding: 12px 14px 10px;
  border: 3px solid var(--dark);
  margin-bottom: 10px;
  position: relative;
}
.masthead-kicker {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--mid);
  text-transform: uppercase;
  margin-bottom: 2px;
}
.masthead h1 {
  font-size: 36px;
  font-weight: 700;
  color: var(--dark);
  line-height: 1;
  letter-spacing: -1px;
  text-shadow: 2px 2px 0 var(--pastel-pink);
}
.masthead-sub {
  font-size: 12px;
  color: var(--mid);
  font-style: italic;
  margin-top: 4px;
}
.masthead-stars {
  position: absolute;
  top: 10px;
  right: 14px;
  font-size: 22px;
  animation: spin 4s linear infinite;
  display: inline-block;
}
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* COUNTER */
.counter-bar {
  text-align: center;
  font-size: 12px;
  color: var(--mid);
  background: var(--paper);
  border: 2px solid var(--muted);
  padding: 4px;
  margin-bottom: 10px;
  font-family: 'Courier New', monospace;
}
.counter-bar a { color: var(--purple-dark); text-decoration: underline; }
.counter-digits {
  background: var(--dark);
  color: var(--pastel-cyan);
  padding: 2px 8px;
  font-size: 16px;
  letter-spacing: 4px;
  border: 1px solid var(--pastel-cyan);
  display: inline-block;
}

/* ANIMATIONS */
.twinkle {
  animation: twinkle 1.2s steps(2) infinite;
  display: inline-block;
}
@keyframes twinkle {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}
@keyframes pulse {
  0% { opacity: 0.5; }
  100% { opacity: 1; }
}
@keyframes flicker {
  0%   { transform: scale(1); }
  25%  { transform: scale(1.3) rotate(-5deg); }
  50%  { transform: scale(1.5) rotate(3deg); }
  75%  { transform: scale(1.2) rotate(-2deg); }
  100% { transform: scale(1); }
}
@keyframes glow {
  0% { border-color: #FF85C2; }
  100% { border-color: #a8c840; }
}

/* LAYOUT */
.main { max-width: 780px; margin: 0 auto; }

/* DIVIDER */
.divider {
  text-align: center;
  font-size: 13px;
  letter-spacing: 6px;
  margin: 6px 0;
  color: var(--muted);
  animation: pulse 2s ease-in-out infinite alternate;
}

/* PET CARDS */
.pet-card {
  background: var(--paper);
  border: 2px solid #d0c8a8;
  border-left: 6px solid var(--pastel-pink);
  padding: 10px 12px;
  margin-bottom: 10px;
}
.in-loving-memory {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--hot-pink-dark);
  margin-bottom: 6px;
}
.pet-header {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
}

/* =============================================
   PET PHOTO CONTAINER
   Use: <div class="pet-emoji">
          <img src="/your-photo.jpg" alt="Pet name">
        </div>
   Sizing is handled here — no inline styles needed.
============================================= */
.pet-emoji {
  flex-shrink: 0;
  background: var(--cream);
  border-width: 2px;
  border-style: solid;
  border-color: #FF85C2;
  padding: 4px;
  line-height: 1;
  animation: glow 2s ease-in-out infinite alternate;
}

.pet-emoji img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  display: block;
}

.pet-name {
  font-size: 20px;
  font-weight: 700;
  color: var(--dark);
  line-height: 1.1;
}
.pet-species {
  font-size: 14px;
  color: var(--purple-dark);
  margin: 2px 0;
  font-style: italic;
}
.pet-dates {
  font-size: 14px;
  color: var(--muted);
}
.pet-obit {
  font-size: 16px;
  color: var(--dark);
  line-height: 1.65;
  border-top: 1px dashed #c0b890;
  padding-top: 8px;
}
.highlight {
  color: var(--chartreuse-dark);
  font-weight: 700;
}
.pet-footer {
  font-size: 12px;
  color: var(--muted);
  margin-top: 8px;
  font-style: italic;
}

/* CANDLES */
.candles {
  color: var(--hot-pink-dark);
  cursor: pointer;
  display: inline-block;
}
.candle-flame { display: inline-block; }
.candles.lit .candle-flame { animation: flicker 0.5s ease-in-out; }

/* SUBMIT BOX */
.submit-box {
  background: var(--pastel-lavender);
  border: 2px solid var(--pastel-purple);
  padding: 12px 14px;
  margin-top: 4px;
  text-align: center;
}
.submit-box h3 {
  color: var(--purple-dark);
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 6px;
}
.submit-box p {
  font-size: 12px;
  color: var(--dark);
  line-height: 1.6;
  margin-bottom: 8px;
}
.submit-box a { color: var(--purple-dark); text-decoration: underline; }

.fake-button {
  background: var(--pastel-lime);
  color: var(--dark);
  border: 3px outset #fff;
  padding: 7px 18px;
  font-family: 'Comic Neue', 'Comic Sans MS', cursive;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  display: inline-block;
}
.fake-button:active { border-style: inset; }

/* FOOTER */
.page-footer {
  text-align: center;
  font-size: 11px;
  color: var(--muted);
  margin-top: 12px;
  border-top: 1px solid #c0b890;
  padding-top: 8px;
  line-height: 1.8;
}
.page-footer a { color: var(--purple-dark); text-decoration: underline; }

/* CUSTOM CURSOR */
* {
  cursor: url('https://cdn.cursors-4u.net/previews/angel-wing-heart-800e0eca-32.webp') 32 32, auto !important;
}