/*
Theme Name: Kristin Hanlin
Theme URI: https://kristinhanlin.art
Description: Custom theme for kristinhanlin.art - neutral cream with bright jeweled accents
Version: 1.5
Author: Kristin Hanlin
Author URI: https://kristinhanlin.art
License: GPL v2 or later
Text Domain: kristin-hanlin
Domain Path: /languages
*/

@import url('https://fonts.googleapis.com/css2?family=Bungee&family=Caveat:wght@400;600;700&family=Permanent+Marker&family=Special+Elite&family=VT323&family=Rubik+Mono+One&family=DM+Serif+Display&family=Redacted+Script:wght@400;700&display=swap');

:root {
  /* --- BASE: Light Mode (Default) --- */
  --paper: oklch(0.98 0.003 250);
  --paper-2: oklch(0.92 0.01 240);
  --ink: oklch(0.15 0.02 220);
  --ink-soft: oklch(0.50 0.02 220);
  
  /* --- NEW BRAND PALETTE --- */
  --studio-teal: oklch(0.55 0.18 195);      /* my art / studio */
  --home-green: oklch(0.55 0.18 130);       /* home / entry point */
  --accent-pink: oklch(0.58 0.28 350);      /* featured / accent */
  --cabinet-gold: oklch(0.72 0.18 70);      /* cabinet of curiosities */
  --accent-emerald: oklch(0.55 0.20 160);   /* supporting accent */
  --accent-plum: oklch(0.48 0.18 310);      /* supporting accent */
  
  /* --- SECTION COLORS --- */
  --color-home: var(--home-green);
  --color-art: var(--studio-teal);
  --color-cabinet: var(--cabinet-gold);
  --color-about: var(--accent-plum);
  --color-contact: var(--cabinet-gold);
  --color-featured: var(--accent-ink);
  
  /* --- LEGACY MAPPINGS (for compatibility) --- */
  --riso-red: var(--accent-pink);
  --riso-blue: var(--studio-teal);
  --riso-yellow: var(--cabinet-gold);
  --riso-green: var(--accent-emerald);
  --riso-pink: var(--accent-pink);
  
  /* --- TYPOGRAPHY --- */
  --font-display: 'Bungee', 'Rubik Mono One', Impact, sans-serif;
  --font-poster: 'Rubik Mono One', 'Bungee', Impact, sans-serif;
  --font-hand: 'Caveat', 'Permanent Marker', cursive;
  --font-marker: 'Permanent Marker', 'Caveat', cursive;
  --font-type: 'Special Elite', 'Courier New', monospace;
  --font-screen: 'VT323', monospace;
  --font-serif: 'DM Serif Display', Georgia, serif;
}

/* --- DARK MODE --- */
@media (prefers-color-scheme: dark) {
  :root {
    --paper: oklch(0.15 0.02 250);
    --paper-2: oklch(0.22 0.02 240);
    --ink: oklch(0.95 0.005 250);
    --ink-soft: oklch(0.70 0.01 220);
  }
}

/* --- DARK MODE TOGGLE CLASS --- */
html[data-theme="dark"] {
  --paper: oklch(0.15 0.02 250);
  --paper-2: oklch(0.22 0.02 240);
  --ink: oklch(0.95 0.005 250);
  --ink-soft: oklch(0.70 0.01 220);
}

html[data-theme="light"] {
  --paper: oklch(0.98 0.003 250);
  --paper-2: oklch(0.92 0.01 240);
  --ink: oklch(0.15 0.02 220);
  --ink-soft: oklch(0.50 0.02 220);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-type);
  font-size: 16px;
  line-height: 1.5;
}

body {
  cursor: auto;
}

/* ENHANCED: Subtle paper texture */
body.kh-paper::before {
  content: '';
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 1;
  background-image: radial-gradient(rgba(0,0,0,0.08) 1px, transparent 1px), radial-gradient(rgba(0,0,0,0.06) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
  mix-blend-mode: multiply;
  opacity: 0.35;
}

.kh-tape {
  position: absolute;
  width: 90px; height: 26px;
  background: var(--studio-teal) / 0.6;
  border-left: 1px dashed rgba(0,0,0,0.08);
  border-right: 1px dashed rgba(0,0,0,0.08);
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  transform: rotate(-6deg);
}
.kh-tape.tape-blue { background: var(--studio-teal) / 0.55; }
.kh-tape.tape-pink { background: var(--accent-pink) / 0.6; }
.kh-tape.tape-gold { background: var(--cabinet-gold) / 0.55; }

.kh-stamp {
  display: inline-block;
  border: 3px solid currentColor;
  padding: 4px 10px 2px;
  font-family: var(--font-display);
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  transform: rotate(-6deg);
  color: var(--accent-pink);
  opacity: 0.85;
  filter: contrast(1.15);
}

.kh-polaroid {
  background: #fafaf4;
  padding: 10px 10px 44px;
  box-shadow: 0 12px 24px -8px rgba(0,0,0,0.3);
  position: relative;
}
.kh-polaroid .caption {
  position: absolute; bottom: 10px; left: 10px; right: 10px;
  text-align: center;
  font-family: var(--font-hand);
  font-size: 1.15rem;
  color: var(--ink-soft);
}

.kh-placeholder {
  display: grid;
  place-items: center;
  background: repeating-linear-gradient(45deg, oklch(0.87 0.04 80) 0 8px, oklch(0.91 0.03 80) 8px 16px);
  color: var(--ink-soft);
  font-family: var(--font-screen);
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  min-height: 120px;
  position: relative;
}
.kh-placeholder::before {
  content: '[ ' attr(data-label) ' ]';
}

/* SECTION-SPECIFIC THEMING */
.kh-section-studio {
  --section-color: var(--color-art);
}

.kh-section-cabinet {
  --section-color: var(--color-cabinet);
}

.kh-section-header {
  color: var(--section-color, var(--ink));
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  transition: color 0.2s ease;
}

.kh-section-number {
  color: var(--section-color, var(--ink));
  font-family: var(--font-display);
  font-weight: 900;
  letter-spacing: 0.15em;
}

a.kh-link {
  color: var(--ink);
  text-decoration: none;
  background-image: linear-gradient(var(--cabinet-gold), var(--cabinet-gold));
  background-repeat: no-repeat;
  background-size: 100% 0.35em;
  background-position: 0 85%;
  padding: 0 2px;
  transition: background-size 0.25s cubic-bezier(0.34, 1.56, 0.64, 1), background-image 0.25s ease;
  position: relative;
}
a.kh-link:hover {
  background-size: 100% 100%;
  background-image: linear-gradient(var(--accent-pink), var(--accent-pink));
}

.kh-btn {
  display: inline-block;
  font-family: var(--font-display);
  background: var(--ink);
  color: var(--paper);
  padding: 10px 18px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border: 2px solid var(--ink);
  box-shadow: 4px 4px 0 var(--accent-pink);
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.15s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.15s ease;
}
.kh-btn:hover {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--accent-pink);
}
.kh-btn:focus-visible {
  outline: 3px solid var(--accent-pink);
  outline-offset: 2px;
}

/* SECTION-SPECIFIC BUTTON VARIANTS */
.kh-btn.kh-btn-studio {
  box-shadow: 4px 4px 0 var(--color-art);
}
.kh-btn.kh-btn-studio:hover {
  box-shadow: 2px 2px 0 var(--color-art);
}

.kh-btn.kh-btn-cabinet {
  box-shadow: 4px 4px 0 var(--color-cabinet);
}
.kh-btn.kh-btn-cabinet:hover {
  box-shadow: 2px 2px 0 var(--color-cabinet);
}

.kh-btn.kh-btn-home {
  box-shadow: 4px 4px 0 var(--home-green);
}
.kh-btn.kh-btn-home:hover {
  box-shadow: 2px 2px 0 var(--home-green);
}

.kh-btn.kh-btn-about {
  background: var(--paper-2) !important;
  border: 1px solid var(--accent-plum) !important;
  color: var(--ink) !important;
  padding: 8px 14px !important;
  font-size: 0.9rem !important;
  box-shadow: none !important;
  transition: all 0.2s ease !important;
}
.kh-btn.kh-btn-about:hover {
  background: var(--accent-plum) !important;
  color: var(--paper) !important;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1) !important;
  transform: none !important;
}

.kh-sticker {
  display: inline-grid;
  place-items: center;
  width: 90px; height: 90px;
  border-radius: 50%;
  background: var(--studio-teal);
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 0.7rem;
  text-align: center;
  padding: 10px;
  line-height: 1.1;
  text-transform: uppercase;
  box-shadow: 0 8px 16px rgba(0,0,0,0.18);
  border: 2px solid var(--ink);
  transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.25s ease;
}
.kh-sticker:hover {
  transform: rotate(-3deg) scale(1.1);
  box-shadow: 0 12px 24px rgba(0,0,0,0.25);
}

a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: 3px solid var(--accent-pink);
  outline-offset: 3px;
}

.kh-skip {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--ink);
  color: var(--paper);
  padding: 10px 16px;
  font-family: var(--font-display);
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-decoration: none;
  z-index: 10000;
}
.kh-skip:focus {
  left: 10px; top: 10px;
}

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

html {
  scroll-padding-top: 32px;
}

img { max-width: 100%; width: auto; height: auto; max-inline-size: 100%; }
a { color: var(--ink); }

/* STICKER SHEET STYLES */
#kh-sticker-toggle {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 9000;
  background: var(--ink);
  color: var(--paper);
  border: 2px solid var(--ink);
  padding: 10px 16px;
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: 0.75rem;
  cursor: pointer;
  transition: transform 0.15s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.15s ease;
  box-shadow: 3px 3px 0 var(--accent-pink);
}

#kh-sticker-toggle:hover {
  transform: translate(1px, 1px);
  box-shadow: 2px 2px 0 var(--accent-pink);
}

#sticker-sheet {
  position: fixed;
  bottom: 80px;
  right: 20px;
  width: 260px;
  background: var(--paper);
  border: 2px solid var(--ink);
  box-shadow: 5px 5px 0 var(--ink);
  padding: 16px;
  z-index: 8999;
  display: none;
  flex-direction: column;
  gap: 12px;
  max-height: 60vh;
  overflow-y: auto;
  animation: slideInSticker 0.3s ease;
}

#sticker-sheet.open {
  display: flex;
}

@keyframes slideInSticker {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.sticker-sheet-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 0;
}

.sticker-sheet-header h3 {
  margin: 0;
  font-size: 0.95rem;
  font-family: var(--font-display);
  text-transform: uppercase;
}

.sticker-sheet-header .close {
  background: none;
  border: none;
  font-size: 1.25rem;
  color: var(--ink);
  padding: 0;
  flex-shrink: 0;
  cursor: pointer;
  transition: color 0.2s ease;
}

.sticker-sheet-header .close:hover {
  color: var(--jewel-ruby);
}

#sticker-sheet .sheet-inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

#sticker-sheet .hint {
  font-size: 0.75rem;
  line-height: 1.4;
  margin: 0;
  padding: 8px;
  background: var(--paper-2);
  border: 1px dashed var(--ink-soft);
}

#sticker-sheet .reset-stickers {
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
  padding: 6px 10px;
  font-family: var(--font-type);
  font-size: 0.7rem;
  cursor: pointer;
  width: 100%;
  transition: transform 0.1s ease, box-shadow 0.1s ease;
}

#sticker-sheet .reset-stickers:hover {
  transform: translate(1px, 1px);
  box-shadow: 2px 2px 0 var(--jewel-ruby);
}

/* WATERMARK ON SINGLE PIECE PAGES ONLY */
.image-wrap {
  position: relative;
}
.image-wrap::after {
  content: '© kristin hanlin';
  position: absolute;
  bottom: 8px;
  right: 8px;
  font-family: var(--font-type);
  font-size: 0.7rem;
  color: var(--paper);
  background: rgba(25, 25, 25, 0.5);
  padding: 3px 6px;
  letter-spacing: 0.05em;
  pointer-events: none;
  z-index: 3;
}

/* ============================================================
   ENHANCED CARD STYLES WITH HOVER & DEPTH
   ============================================================ */

.work-card,
.cabinet-card {
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), 
              box-shadow 0.35s ease,
              filter 0.35s ease;
  will-change: transform, box-shadow;
}

.work-card:hover,
.cabinet-card:hover {
  transform: translateY(-8px) scale(1.03);
  box-shadow: 0 20px 40px rgba(0,0,0,0.2);
  filter: brightness(1.05);
}

/* Cabinet card specific enhancements */
.cabinet-card {
  box-shadow: 0 8px 16px rgba(0,0,0,0.12);
}

.cabinet-card-img {
  position: relative;
  overflow: hidden;
}

.cabinet-card-img img {
  transition: transform 0.3s ease, filter 0.3s ease;
}

/* ============================================================
   ANIMATION STAGGER FOR FADE-IN
   ============================================================ */

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.cabinet-card,
.work-card {
  animation: fadeInUp 0.6s ease-out backwards;
}

/* Stagger effect: each subsequent item waits a bit longer */
.cabinet-card:nth-child(1) { animation-delay: 0.05s; }
.cabinet-card:nth-child(2) { animation-delay: 0.1s; }
.cabinet-card:nth-child(3) { animation-delay: 0.15s; }
.cabinet-card:nth-child(4) { animation-delay: 0.2s; }
.cabinet-card:nth-child(5) { animation-delay: 0.25s; }
.cabinet-card:nth-child(6) { animation-delay: 0.3s; }
.cabinet-card:nth-child(7) { animation-delay: 0.35s; }
.cabinet-card:nth-child(8) { animation-delay: 0.4s; }
.cabinet-card:nth-child(9) { animation-delay: 0.45s; }
.cabinet-card:nth-child(10) { animation-delay: 0.5s; }

/* ============================================================
   CABINET MASONRY LAYOUT
   ============================================================ */

.feed {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  grid-auto-rows: auto;
}

/* Variant 1: Wider cards (2 columns on desktop) */
.cabinet-card.variant-wide {
  grid-column: span 1;
}

@media (min-width: 900px) {
  .cabinet-card.variant-wide {
    grid-column: span 2;
  }
}

/* Variant 2: Taller cards */
.cabinet-card.variant-tall .cabinet-card-img {
  height: 360px;
}

/* Variant 3: Featured/highlighted */
.cabinet-card.variant-featured {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 24px;
}

.cabinet-card.variant-featured .cabinet-card-img {
  grid-column: 1;
}

.cabinet-card.variant-featured .cabinet-card-body {
  grid-column: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (max-width: 768px) {
  .cabinet-card.variant-featured {
    grid-template-columns: 1fr;
  }
  .cabinet-card.variant-featured .cabinet-card-img,
  .cabinet-card.variant-featured .cabinet-card-body {
    grid-column: 1;
  }
}

/* ============================================================
   FEATURED CURIOSITY BOX PROMINENCE
   ============================================================ */

.featured-curiosity {
  background: var(--paper-2);
  border: 2px solid var(--ink);
  padding: 24px;
  margin-bottom: 40px;
  box-shadow: 0 12px 28px rgba(0,0,0,0.15);
  position: relative;
}

.featured-curiosity::before {
  content: '';
  position: absolute;
  top: 16px;
  right: 16px;
  width: 24px;
  height: 24px;
  border-top: 2px solid var(--accent-pink);
  border-right: 2px solid var(--accent-pink);
}

.featured-curiosity::after {
  content: '';
  position: absolute;
  bottom: 16px;
  left: 16px;
  width: 24px;
  height: 24px;
  border-bottom: 2px solid var(--cabinet-gold);
  border-left: 2px solid var(--cabinet-gold);
}

.featured-label {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent-pink);
  margin-bottom: 16px;
  padding: 4px 8px;
  border: 1px solid var(--accent-pink);
}

.featured-entry-style {
  background: transparent;
}

/* ============================================================
   WORK CARD ENHANCEMENTS
   ============================================================ */

.work-card {
  box-shadow: 0 8px 16px rgba(0,0,0,0.12);
}

.work-card-img {
  position: relative;
  overflow: hidden;
  background: var(--paper-2);
}

.work-card-img img {
  transition: transform 0.3s ease;
}

/* ============================================================
   MOBILE REFINEMENTS
   ============================================================ */

@media screen and (max-width: 782px) {
    /* Ensure the pencil cursor never accidentally triggers on touch */
    #kh-pointer {
        display: none !important;
    }

    /* Remove the extra padding sometimes needed for fixed footer buttons */
    body {
        padding-bottom: 0 !important;
    }

    /* Optional: Center the footer text since the buttons are gone */
    .kh-footer {
        margin-top: 40px;
        padding-bottom: 40px;
    }

    /* Adjust masonry on mobile */
    .feed {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .cabinet-card.variant-wide {
        grid-column: 1 !important;
    }

    .cabinet-card.variant-featured {
        grid-template-columns: 1fr;
    }
}