/* Small, tasteful defaults; most styling via Tailwind classes. */

:root {
  --ppb-bg: #faf7f3;
  --ppb-surface: #ffffff;
  --ppb-text: #1f1b16;
  --ppb-muted: #6b625b;
  --ppb-border: #eadfd6;
  --ppb-primary: #8f4a2d;
  --ppb-primary-contrast: #ffffff;
  --ppb-link: #8f4a2d;
  --ppb-accent: #b07b5b;
  --ppb-ring: #e7b59b;
}

@media (max-width: 420px) {
  html { font-size: 15px; }
}

.ppb-body {
  background: var(--ppb-bg);
  color: var(--ppb-text);
}

/* Subtle texture for a more premium feel (theme-aware). */
.ppb-body {
  background-image:
    radial-gradient(900px 500px at 15% 5%, rgba(255, 255, 255, 0.75), rgba(255, 255, 255, 0)),
    radial-gradient(800px 520px at 85% 15%, rgba(255, 255, 255, 0.55), rgba(255, 255, 255, 0)),
    radial-gradient(900px 520px at 60% 90%, rgba(255, 255, 255, 0.45), rgba(255, 255, 255, 0));
  background-attachment: fixed;
}

@media (max-width: 768px) {
  .ppb-body { background-attachment: scroll; }
}

@media (prefers-reduced-motion: reduce) {
  .ppb-body { background-attachment: scroll; }
}

.ppb-surface { background-color: var(--ppb-surface); }
.ppb-muted { color: var(--ppb-muted); }
.ppb-border { border-color: var(--ppb-border); }
.ppb-link { color: var(--ppb-link); }

.ppb-no-scrollbar {
  scrollbar-width: none;
}

.ppb-no-scrollbar::-webkit-scrollbar {
  display: none;
}

.ppb-header {
  background: rgba(255, 255, 255, 0.82);
}

@supports (color: color-mix(in srgb, white, black)) {
  .ppb-header {
    background: color-mix(in srgb, var(--ppb-surface) 82%, transparent);
  }
}

.ppb-btn-primary {
  background: var(--ppb-primary);
  color: var(--ppb-primary-contrast);
}

.ppb-btn-primary:hover {
  filter: brightness(0.96);
}

.ppb-btn-secondary {
  background: var(--ppb-surface);
  border: 1px solid var(--ppb-border);
  color: var(--ppb-text);
}

.ppb-btn-secondary:hover {
  filter: brightness(0.985);
}

.ppb-card {
  border: 1px solid var(--ppb-border);
  background: var(--ppb-surface);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}

.ppb-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgba(0,0,0,0.08);
}

.ppb-media-placeholder {
  background: rgba(255, 255, 255, 0.72);
}

@supports (color: color-mix(in srgb, white, black)) {
  .ppb-media-placeholder {
    background:
      radial-gradient(520px 240px at 20% 15%, color-mix(in srgb, var(--ppb-primary) 14%, transparent), transparent 62%),
      radial-gradient(520px 240px at 80% 20%, color-mix(in srgb, var(--ppb-accent) 16%, transparent), transparent 60%),
      color-mix(in srgb, var(--ppb-surface) 92%, var(--ppb-bg) 8%);
  }
}

.ppb-kicker {
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  font-size: 0.72rem;
  color: var(--ppb-muted);
}

.ppb-display {
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
}

.ppb-navlink {
  display: flex;
  align-items: center;
  border-radius: 0.75rem;
  transition: background-color 140ms ease, filter 140ms ease;
}

.ppb-navlink:hover {
  background: rgba(0,0,0,0.04);
}

@supports (color: color-mix(in srgb, white, black)) {
  .ppb-navlink:hover {
    background: color-mix(in srgb, var(--ppb-surface) 86%, var(--ppb-primary) 14%);
  }
}

.ppb-navlink-active {
  background: rgba(0,0,0,0.05);
}

@supports (color: color-mix(in srgb, white, black)) {
  .ppb-navlink-active {
    background: color-mix(in srgb, var(--ppb-surface) 82%, var(--ppb-primary) 18%);
  }
}

/* Owner Panel utilities */
.ppb-table-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}

.ppb-table {
  width: 100%;
  font-size: 0.875rem;
}

.ppb-table thead {
  background: rgba(0,0,0,0.03);
  color: var(--ppb-muted);
}

@supports (color: color-mix(in srgb, white, black)) {
  .ppb-table thead {
    background: color-mix(in srgb, var(--ppb-surface) 92%, var(--ppb-border) 8%);
  }
}

.ppb-table th {
  text-align: left;
  padding: 0.85rem 1rem;
  font-weight: 600;
}

.ppb-table td {
  padding: 0.85rem 1rem;
  border-top: 1px solid var(--ppb-border);
  vertical-align: top;
}

.ppb-table tr:hover td {
  background: rgba(0,0,0,0.02);
}

.ppb-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.2rem 0.55rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  border: 1px solid var(--ppb-border);
  background: color-mix(in srgb, var(--ppb-border) 20%, transparent);
  color: var(--ppb-text);
}

.ppb-badge-muted {
  background: color-mix(in srgb, var(--ppb-border) 18%, transparent);
  color: var(--ppb-muted);
}

.ppb-badge-success {
  background: color-mix(in srgb, #34d399 18%, transparent);
  border-color: color-mix(in srgb, #34d399 30%, var(--ppb-border));
}

.ppb-badge-warn {
  background: color-mix(in srgb, #f59e0b 18%, transparent);
  border-color: color-mix(in srgb, #f59e0b 30%, var(--ppb-border));
}

.ppb-spotlight {
  background: rgba(255, 255, 255, 0.72);
}

@supports (color: color-mix(in srgb, white, black)) {
  .ppb-spotlight {
    background:
      radial-gradient(900px 240px at 10% 20%, color-mix(in srgb, var(--ppb-accent) 24%, transparent), transparent 60%),
      radial-gradient(800px 220px at 90% 10%, color-mix(in srgb, var(--ppb-primary) 18%, transparent), transparent 55%),
      color-mix(in srgb, var(--ppb-surface) 92%, var(--ppb-bg) 8%);
  }
}

.ppb-pill {
  background: var(--ppb-primary);
  color: var(--ppb-primary-contrast);
}

.ppb-btn-primary:focus-visible,
.ppb-btn-secondary:focus-visible,
a:focus-visible,
button:focus-visible {
  outline: 3px solid var(--ppb-ring);
  outline-offset: 2px;
}

.ppb-input {
  background: var(--ppb-surface);
  color: var(--ppb-text);
  border-color: var(--ppb-border);
}

.ppb-input:focus {
  box-shadow: 0 0 0 4px rgba(231, 181, 155, 0.35);
}

.ppb-input::placeholder {
  color: var(--ppb-muted);
}

select.ppb-input {
  background-color: var(--ppb-surface);
}

.prose {
  color: var(--ppb-text);
}

.prose :where(h1,h2,h3,h4,h5,h6,strong) {
  color: var(--ppb-text);
}

.prose :where(a) {
  color: var(--ppb-link);
}

.prose :where(code,kbd) {
  color: var(--ppb-text);
}

.prose a { text-decoration: underline; }

/* Seasonal effects are intentionally subtle. */
.effect-snow::before,
.effect-hearts::before,
.effect-sun::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.12;
  mix-blend-mode: multiply;
}

.effect-snow::before {
  background-image: radial-gradient(circle at 20% 20%, rgba(255,255,255,0.9), rgba(255,255,255,0) 55%),
                    radial-gradient(circle at 70% 30%, rgba(255,255,255,0.8), rgba(255,255,255,0) 55%),
                    radial-gradient(circle at 35% 75%, rgba(255,255,255,0.85), rgba(255,255,255,0) 55%);
}

.effect-hearts::before {
  background-image: radial-gradient(circle at 25% 30%, rgba(255,105,180,0.7), rgba(255,105,180,0) 55%),
                    radial-gradient(circle at 80% 20%, rgba(255,105,180,0.6), rgba(255,105,180,0) 55%),
                    radial-gradient(circle at 60% 80%, rgba(255,105,180,0.55), rgba(255,105,180,0) 55%);
}

.effect-sun::before {
  background-image: radial-gradient(circle at 80% 10%, rgba(255,204,0,0.7), rgba(255,204,0,0) 60%);
}

@media (prefers-reduced-motion: reduce) {
  .effect-snow::before,
  .effect-hearts::before,
  .effect-sun::before {
    opacity: 0.07;
  }
}

/* Glass + hero helpers */
.ppb-glass {
  background: rgba(255, 255, 255, 0.70);
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

@supports (color: color-mix(in srgb, white, black)) {
  .ppb-glass {
    background: color-mix(in srgb, var(--ppb-surface) 70%, transparent);
    border-color: color-mix(in srgb, var(--ppb-border) 70%, transparent);
  }
}

.ppb-hero {
  position: relative;
  overflow: hidden;
  border-radius: 2rem;
  border: 1px solid var(--ppb-border);
}

.ppb-hero::before {
  content: "";
  position: absolute;
  inset: -2px;
  background-image:
    radial-gradient(900px 340px at 15% 10%, rgba(255, 255, 255, 0.70), rgba(255, 255, 255, 0)),
    radial-gradient(900px 320px at 90% 0%, rgba(255, 255, 255, 0.55), rgba(255, 255, 255, 0)),
    linear-gradient(135deg, rgba(0, 0, 0, 0.32), rgba(0, 0, 0, 0.06)),
    var(--ppb-hero-bg, none);
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.02);
  transform: scale(1.03);
  opacity: 0.92;
}

.ppb-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(250, 247, 243, 0.10), rgba(250, 247, 243, 0.92));
  pointer-events: none;
}

.ppb-hero > * {
  position: relative;
  z-index: 1;
}

.ppb-card {
  border: 1px solid var(--ppb-border);
  background: var(--ppb-surface);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}

.ppb-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 46px rgba(0,0,0,0.10);
}

.ppb-image-tile {
  position: relative;
}

.ppb-image-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.30));
  opacity: 0.72;
  pointer-events: none;
}

.ppb-section-title {
  text-shadow: 0 10px 22px rgba(0,0,0,0.08);
}
