:root{
  --ink:#111;
  --paper:#2f2f2ff0;
  --muted:#c50fc9;
  --accent:#000;
  font-size: clamp(12px, 2.5vw, 16px);
}
*{box-sizing:border-box}
html,body,#app{height:100%;margin:0;font-family:'Patrick Hand', 'Caveat', 'Indie Flower', system-ui, -apple-system, 'Segoe UI', Roboto, Arial;background:var(--paper);color:var(--ink);overflow:hidden;}
body{
    background-image: url(img/logo.png)!important;  zoom: calc(100vw / 400);
}
/* subtle paper texture */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(rgba(0,0,0,0.02) 1px, transparent 1px);background-size:14px 14px;opacity:0.6;mix-blend-mode:multiply;
}

.stage{position:absolute;inset:0;height:100vh;padding:24px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;opacity:0;transform:translateY(2vh);transition:opacity .45s ease, transform .45s ease;pointer-events:none;visibility:hidden}
.stage.active{opacity:1;transform:none;pointer-events:auto;visibility:visible;z-index:5;}

/* Password gate specific tweaks */
.gate-panel{max-width:460px;width:92%;margin:auto;background:rgba(255,255,255,0.98);padding:20px;border-radius:12px;box-shadow:0 12px 30px rgba(0,0,0,0.06);text-align:center}
.gate-input{width:100%;padding:10px 12px;border-radius:10px;border:2px dashed var(--ink);font-family:inherit;font-size:16px}
.gate-actions{display:flex;gap:10px;justify-content:center;margin-top:10px}
.gate-error{color:#a00;margin-top:10px;font-size:14px}

.stage-head{max-width:800px;text-align:center;margin-bottom:18px}
.stage h1{font-size:32px;margin:10px 0}
.stage .sub{color:var(--muted);font-size:14px;margin:0}

/* Masonry grid */
.masonry{width:100%;max-width:1000px;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
.m-item{background:#fff;padding:6px;border-radius:12px;position:relative;box-shadow:0 6px 18px rgba(0,0,0,0.06)}
.m-item img{width:100%;height:160px;object-fit:cover;border-radius:10px;display:block;cursor:pointer;filter:grayscale(.02) contrast(1.02)}

/* doodle-like button */
.doodle-btn{color:white;font-family:inherit;background:transparent;border:2px dashed white;padding:10px 14px;border-radius:12px;cursor:pointer;display:inline-block;font-size:16px}
.doodle-btn:hover{transform:translateY(-2px)}

.actions{margin-top:18px}

/* Slideshow */
.slideshow{position:fixed;inset:0;z-index:0;pointer-events:none}
.sl-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.2s ease;transform-origin:center;filter:grayscale(1) contrast(1.05) brightness(.98)}
.sl-slide.visible{opacity:1}
.sl-slide.visible{animation:pan 14s linear infinite}
@keyframes pan{0%{transform:scale(1) translateY(0)}50%{transform:scale(1.04) translateY(-3%)}100%{transform:scale(1) translateY(0)}}
.story-panel{position:relative;z-index:2;max-width:820px;background:rgba(255,255,255,0.9);padding:24px;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,0.06);margin-top:12vh;text-align:center;max-height:calc(100vh - 140px);overflow:auto;-webkit-overflow-scrolling:touch}
.wiggle-title{font-size:28px;margin:0 0 12px}
.story-text{font-size:18px;line-height:1.5;color:var(--ink);min-height:70px}
.hidden{display:none}

.center{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:18px}
.letter{max-width:720px;padding:24px;text-align:left;background:rgba(255,255,255,0.96);border-radius:12px;box-shadow:0 8px 20px rgba(0,0,0,0.06);max-height:calc(100vh - 140px);overflow:auto;-webkit-overflow-scrolling:touch}
.letter h2{font-size:28px;margin:0 0 12px}
.letter p{font-size:18px;margin:0}

.site-footer{display:flex;align-items:center;gap:10px;margin-top:18px}
.heart{font-size:24px;color:var(--accent);animation:beat 1s ease-in-out infinite}
@keyframes beat{0%{transform:scale(1)}25%{transform:scale(1.25)}50%{transform:scale(1)}75%{transform:scale(1.12)}100%{transform:scale(1)}}

/* wiggle / hand-drawn effect */
.wiggle-title{display:inline-block;animation:wiggle 4s ease-in-out infinite}
@keyframes wiggle{0%{transform:rotate(-0.6deg)}50%{transform:rotate(0.8deg)}100%{transform:rotate(-0.6deg)}}

/* small screens */
@media (max-width:640px){
  .m-item img{height:140px}
  .stage{padding:28px 14px}
  .story-panel{margin-top:8vh;padding:18px}
  .wiggle-title{font-size:22px}
}

/* New layout styles for Intro / Chapters / Outro */
.centered{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:18px}
.centered.column{padding:28px}
.cover{width:min(520px,88vw);height:min(420px,60vh);display:grid;place-items:center;border-radius:14px;background:#fff;position:relative;padding:18px}
.cover::before{content:'';position:absolute;inset:-10px;border:3px dashed var(--ink);border-radius:18px;z-index:-1}
.cover img{width:86%;height:86%;object-fit:contain;display:block;border-radius:8px}

.bg-slideshow{position:fixed;inset:0;z-index:0;overflow:hidden}
.bg-slideshow::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(0,0,0,0.30), rgba(0,0,0,0.18));pointer-events:none}
.bg-slide{position:absolute;inset:0;background-position:center center;background-size:cover;background-repeat:no-repeat;opacity:0;transition:opacity 1.4s ease, transform 10s linear, background-position 1.2s ease;filter:grayscale(0.9) contrast(1.03) brightness(.9);transform-origin:center center}
.bg-slide.visible{opacity:1;transform:scale(1.06)}
/* make image focal point slightly higher on small screens so faces/subjects stay visible */
@media (max-width:640px){
  .bg-slide{background-position:center 35%}
}

.panel{position:relative;z-index:999;max-width:880px;width:92%;margin:auto;background:rgba(255,255,255,0);backdrop-filter:blur(3px);padding:22px;border-radius:14px;box-shadow:0 18px 40px rgba(0,0,0,0.08);text-align:center;transform:translateY(4px);animation:panel-in .6s ease;color:var(--ink);pointer-events:auto;max-height:calc(100vh - 120px);overflow:auto;-webkit-overflow-scrolling:touch}

@keyframes panel-in{0%{opacity:0;transform:translateY(12px) scale(.995)}100%{opacity:1;transform:translateY(0) scale(1)}}
.panel h2{font-size:26px;margin:0 0 12px;color:#c50fc9;opacity:1}
.chapter-text{font-size:18px;line-height:1.5;color:white;min-height:120px;opacity:1;transition:opacity .5s ease}
.panel-actions{margin-top:16px}

.doodle-btn{transition:transform .18s ease, box-shadow .18s ease;display:inline-flex;align-items:center;justify-content:center}
.doodle-btn:focus{outline:none;box-shadow:0 0 0 4px rgba(0,0,0,0.06)}

/* wiggle animation for interactive hand-drawn feel (subtle) */
.doodle-btn{animation:button-wiggle 4s ease-in-out infinite}
@keyframes button-wiggle{0%{transform:rotate(-0.6deg)}50%{transform:rotate(0.7deg)}100%{transform:rotate(-0.6deg)}}

/* ensure text readable on small screens */
@media (max-width:640px){
  .panel{padding:18px;max-height:calc(100vh - 48px)}
  .story-panel{max-height:calc(100vh - 48px)}
  .letter{max-height:calc(100vh - 48px)}
  .cover{width:86vw;height:48vw}
  .bg-slideshow::after{background:linear-gradient(rgba(0,0,0,0.24), rgba(0,0,0,0.12));}
  .chapter-text{font-size:16px;min-height:90px}
  .gate-panel{padding:14px}
  .gate-input{font-size:15px}
}

/* Cover image improvements */
.cover img{max-width:100%;max-height:100%;width:auto;height:auto;display:block}
.cover{display:flex;align-items:center;justify-content:center}

 /* intro header (logo + title) */
 .intro-header{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.intro-logo{width:56px;height:56px;border-radius:12px;object-fit:cover;transform-origin:center;transition:transform .45s ease;animation:logo-float 4.5s ease-in-out infinite}
.intro-logo:hover{transform:translateY(-4px) rotate(-6deg)}
.site-title{font-family:'Caveat','Patrick Hand',cursive;font-size:28px;margin:0;color:var(--ink);letter-spacing:0.6px;display:flex;align-items:center;gap:8px}
.site-sub{font-size:13px;color:var(--muted);margin-top:2px}
.site-title-wrap{display:flex;flex-direction:column;align-items:flex-start}
.title-underline{margin-left:6px;transform:translateY(6px);opacity:0.95}
.title-heart{color:#f05a75;margin-left:6px;font-size:14px;transform:translateY(1px);display:inline-block}

/* autonomous subtle float for logo */
@keyframes logo-float{
  0%{transform:translateY(0) rotate(-1deg)}
  25%{transform:translateY(-4px) rotate(1deg)}
  50%{transform:translateY(0) rotate(-1deg)}
  75%{transform:translateY(3px) rotate(2deg)}
  100%{transform:translateY(0) rotate(-1deg)}
}

/* Respect reduced motion preference */
@media (prefers-reduced-motion: reduce){
  .intro-logo, .doodle-btn, .logo-drop, .bg-slide, .panel, .wiggle-title, .doodle-btn{animation:none!important;transition:none!important}
}

/* Mobile: center header, stack logo above title and increase logo size slightly */
@media (max-width:640px){
  .intro-header{flex-direction:column;gap:8px;align-items:center;text-align:center}
  .intro-logo{width:72px;height:72px;animation-duration:5s}
  .site-title{font-size:22px}
  .site-sub{font-size:13px}
  .site-title-wrap{align-items:center}
}

.logo-rain{position:fixed;inset:0;pointer-events:none;z-index:2}
.logo-drop{position:absolute;will-change:transform,opacity;opacity:0;transform:translateY(-20vh);animation-name:logo-fall;animation-timing-function:linear;animation-fill-mode:forwards}
@keyframes logo-fall{
  0%{opacity:0;transform:translateY(-10vh) rotate(0deg)}
  10%{opacity:1}
  100%{opacity:1;transform:translateY(110vh) rotate(360deg)}
}

/* smaller drops on mobile */
@media (max-width:640px){
  .logo-drop{width:26px;height:26px}
}

