@import "https://fonts.googleapis.com/css2?family=Caveat:wght@500;700&family=Patrick+Hand&family=Crimson+Pro:ital,wght@0,400;0,600;1,400&display=swap";:root{--paper:#f6ecd5;--paper-edge:#e9dcbe;--paper-deep:#efe2c5;--ink:#3a2a1a;--ink-soft:#6b5740;--ink-faint:#978265;--accent:#b04a2f;--accent-soft:#d8896f;--sage:#8aa17a;--rose:#c9806e;--mustard:#c79d3a;--tape:#d6c08299;--tape-dark:#b09141a6;--hand:"Caveat", "Patrick Hand", cursive;--print:"Patrick Hand", "Caveat", cursive;--serif:"Crimson Pro", Georgia, serif;font-family:var(--serif);color:var(--ink);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-size:17px;line-height:1.5}*{box-sizing:border-box}html,body{background-color:var(--paper);background-image:radial-gradient(circle at 20% 20%,#fff0c880,#0000 60%),radial-gradient(circle at 80% 80%,#c8a0642e,#0000 55%),repeating-radial-gradient(circle,#785a3206 0 2px,#0000 2px 5px);min-height:100%;margin:0;padding:0}#root{min-height:100vh}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:var(--ink)}::selection{background:var(--mustard);color:var(--ink)}.app{max-width:1180px;margin:0 auto;padding:24px 28px 80px}.masthead{text-align:center;border-bottom:2px dashed var(--ink-faint);margin-bottom:22px;padding:36px 0 18px}.masthead-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.masthead-inner>div{text-align:left}.title{font-family:var(--hand);color:var(--ink);letter-spacing:-1px;margin:0;font-size:64px;font-weight:700;line-height:1}.subtitle{font-family:var(--print);color:var(--ink-soft);margin:6px 0 0;font-size:18px}.toolbar{background:var(--paper-deep);border:1px solid var(--paper-edge);border-radius:6px;flex-wrap:wrap;align-items:flex-end;gap:14px 22px;margin-bottom:26px;padding:14px 18px;display:flex;position:relative;box-shadow:0 2px #785a3214}.toolbar:before{content:"";background:var(--tape);width:70px;height:22px;position:absolute;top:-12px;left:32px;transform:rotate(-3deg);box-shadow:0 1px 2px #00000014}.toolbar-group{align-items:center;gap:10px;display:flex}.search-group{flex:220px}.search-input{border:1px solid var(--paper-edge);width:100%;font-family:var(--print);background:#fff8e8;border-radius:4px;padding:8px 12px;font-size:17px}.search-input:focus{outline:2px solid var(--accent-soft);outline-offset:-1px}.date-group{flex-wrap:wrap}.mini-label{font-family:var(--print);color:var(--ink-soft);align-items:center;gap:6px;font-size:15px;display:flex}.mini-label input{border:1px solid var(--paper-edge);background:#fff8e8;border-radius:4px;padding:5px 8px;font-size:14px}.view-toggle{margin-left:auto}.tab{font-family:var(--print);color:var(--ink-soft);border-bottom:2px solid #0000;padding:6px 14px;font-size:16px;transition:color .15s,border-color .15s}.tab:hover{color:var(--ink)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.btn{font-family:var(--print);white-space:nowrap;border:1px solid #0000;border-radius:4px;align-items:center;gap:6px;padding:8px 16px;font-size:16px;transition:transform 80ms,background .15s,box-shadow .15s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--accent);color:#fff7e6;box-shadow:0 2px #0000001f}.btn.primary:hover:not(:disabled){background:#95402a}.btn.ghost{border-color:var(--ink-faint);color:var(--ink);background:0 0}.btn.ghost:hover:not(:disabled){background:#785a3214}.btn.danger{border-color:var(--rose);color:var(--rose);background:0 0}.btn.danger:hover:not(:disabled){background:var(--rose);color:#fff}.btn.tiny{padding:4px 10px;font-size:13px}.btn.big{padding:10px 20px;font-size:18px}.file-btn{cursor:pointer}.page{min-height:50vh}.grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:36px 28px;padding:12px 6px 24px;display:grid}.polaroid{text-align:center;font-family:var(--hand);color:var(--ink);background:#fffaf0;padding:12px 12px 8px;transition:transform .15s,box-shadow .15s;display:block;box-shadow:0 6px 14px #3c28142e,0 1px 2px #3c28141a}.polaroid.card{cursor:pointer;border:none;width:100%}.polaroid.card:nth-child(3n){transform:rotate(-1.3deg)}.polaroid.card:nth-child(3n+1){transform:rotate(.9deg)}.polaroid.card:nth-child(3n+2){transform:rotate(-.4deg)}.polaroid.card:hover{z-index:2;transform:rotate(0)translateY(-3px);box-shadow:0 10px 20px #3c281438,0 2px 4px #3c28141f}.photo-wrap{aspect-ratio:1;background:#efe7d3;width:100%;position:relative;overflow:hidden}.photo-wrap img{object-fit:cover;width:100%;height:100%;display:block}.corner{pointer-events:none;background:linear-gradient(135deg,#50371e8c 0%,#50371e33 50%,#0000 51%);width:22px;height:22px;position:absolute}.corner.tl{top:0;left:0}.corner.tr{top:0;right:0;transform:rotate(90deg)}.corner.br{bottom:0;right:0;transform:rotate(180deg)}.corner.bl{bottom:0;left:0;transform:rotate(270deg)}.caption{padding:8px 4px 2px}.caption-name{font-family:var(--hand);color:var(--ink);font-size:26px;font-weight:700;line-height:1}.caption-sub{font-family:var(--print);color:var(--ink-soft);margin-top:4px;font-size:14px}.caption-date{font-family:var(--print);color:var(--ink-faint);margin-top:2px;font-size:13px}.list{flex-direction:column;gap:10px;padding:4px;display:flex}.row{border:1px solid var(--paper-edge);border-left:4px solid var(--accent-soft);text-align:left;width:100%;font-family:var(--serif);color:var(--ink);background:#fffaf0;border-radius:4px;grid-template-columns:76px 1fr auto;align-items:center;gap:16px;padding:10px 14px;transition:transform .1s,box-shadow .15s;display:grid}.row:hover{transform:translate(2px);box-shadow:0 4px 8px #3c28141f}.row-thumb{border:3px solid #fff8e8;width:76px;height:76px;overflow:hidden;box-shadow:0 1px 3px #00000026}.row-thumb img{object-fit:cover;width:100%;height:100%;display:block}.row-name{font-family:var(--hand);color:var(--ink);font-size:26px;font-weight:700;line-height:1}.row-species{font-family:var(--print);color:var(--ink-soft);margin-top:2px;font-size:14px}.row-bio{color:var(--ink-soft);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:6px;font-size:14px;display:-webkit-box;overflow:hidden}.row-meta{text-align:right;font-family:var(--print);color:var(--ink-soft)}.row-date{color:var(--ink);font-size:14px}.row-source{color:var(--ink-faint);margin-top:2px;font-size:13px;font-style:italic}.empty{text-align:center;font-family:var(--hand);color:var(--ink-faint);padding:80px 20px;font-size:28px}.footer{text-align:center;border-top:2px dashed var(--ink-faint);font-family:var(--print);color:var(--ink-faint);margin-top:36px;padding-top:18px;font-size:14px}.modal-backdrop{z-index:50;background:#28190f8c;justify-content:center;align-items:center;padding:20px;animation:.18s ease-out fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:#fffaf0 repeating-linear-gradient(#0000 0 27px,#785a320f 27px 28px);border-radius:4px;width:100%;max-width:760px;max-height:90vh;padding:28px 30px 24px;position:relative;overflow-y:auto;box-shadow:0 18px 50px #00000059}.modal-tape{background:var(--tape-dark);width:120px;height:24px;position:absolute;top:-12px;left:50%;transform:translate(-50%)rotate(-2deg);box-shadow:0 2px 4px #0000001f}.close-x{font-size:28px;font-family:var(--hand);color:var(--ink-soft);width:36px;height:36px;line-height:1;position:absolute;top:8px;right:12px}.close-x:hover{color:var(--accent)}.sheet-title{font-family:var(--hand);text-align:center;color:var(--ink);margin:0 0 14px;font-size:40px;font-weight:700}.form-grid{grid-template-columns:220px 1fr;align-items:start;gap:22px;display:grid}@media (width<=600px){.form-grid{grid-template-columns:1fr}.photo-slot{justify-self:center}}.photo-slot{flex-direction:column;align-items:center;gap:12px;display:flex}.polaroid.small .photo-wrap,.polaroid.small>img{width:196px}.polaroid.small{padding:10px 10px 6px}.polaroid.small img{object-fit:cover;width:196px;height:196px;display:block}.photo-empty{border:2px dashed var(--ink-faint);width:196px;height:196px;font-family:var(--hand);color:var(--ink-faint);text-align:center;background:#f1e6cb;justify-content:center;align-items:center;padding:12px;font-size:22px;display:flex}.fields{grid-template-columns:1fr 1fr;gap:12px 14px;display:grid}.field{flex-direction:column;gap:4px;display:flex}.field.full{grid-column:1/-1}.field>span{font-family:var(--print);color:var(--ink-soft);font-size:14px}.field input,.field textarea{border:1px solid var(--paper-edge);font-family:var(--serif);resize:vertical;background:#fff8e8;border-radius:4px;padding:8px 10px;font-size:16px}.field input:focus,.field textarea:focus{outline:2px solid var(--accent-soft);outline-offset:-1px}.form-error{color:var(--accent);font-family:var(--print);text-align:center;margin-top:12px}.form-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.detail-layout{grid-template-columns:minmax(220px,320px) 1fr;align-items:start;gap:28px;margin-top:6px;display:grid}@media (width<=640px){.detail-layout{grid-template-columns:1fr}.polaroid.big{justify-self:center}}.polaroid.big{width:100%;max-width:320px;transform:rotate(-1.5deg)}.polaroid.big img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.detail-name{font-family:var(--hand);color:var(--ink);margin:0;font-size:48px;font-weight:700;line-height:1}.detail-species{font-family:var(--print);color:var(--ink-soft);margin:4px 0 14px;font-size:18px}.detail-facts{font-family:var(--print);grid-template-columns:auto 1fr;gap:6px 14px;margin:0 0 18px;display:grid}.detail-facts dt{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-size:14px}.detail-facts dd{color:var(--ink);margin:0;font-size:17px}.detail-bio h3{font-family:var(--hand);color:var(--accent);margin:0 0 6px;font-size:24px}.detail-bio p{font-family:var(--serif);color:var(--ink);white-space:pre-wrap;margin:0;font-size:17px;line-height:1.6}.detail-actions{gap:10px;margin-top:22px;display:flex}.gate{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.gate-card{text-align:center;background:#fffaf0 repeating-linear-gradient(#0000 0 27px,#785a320f 27px 28px);border-radius:4px;width:100%;max-width:420px;padding:40px 38px 32px;position:relative;transform:rotate(-1deg);box-shadow:0 14px 30px #3c281440}.gate-tape{background:var(--tape);width:140px;height:26px;position:absolute;top:-14px;left:50%;transform:translate(-50%)rotate(3deg);box-shadow:0 2px 4px #0000001a}.gate-title{font-family:var(--hand);color:var(--ink);margin:0;font-size:56px;font-weight:700;line-height:1}.gate-sub{font-family:var(--print);color:var(--ink-soft);margin:8px 0 24px}.gate-form{flex-direction:column;gap:10px;display:flex}.gate-label{font-family:var(--print);color:var(--ink-faint);text-align:left;letter-spacing:.05em;font-size:14px}.gate-input{border:1px solid var(--paper-edge);font-family:var(--serif);background:#fff8e8;border-radius:4px;padding:10px 14px;font-size:18px}.gate-input:focus{outline:2px solid var(--accent-soft);outline-offset:-1px}.gate-input.shake{border-color:var(--accent);animation:.35s shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.gate-error{font-family:var(--print);color:var(--accent);margin:0;font-size:15px}@media (width<=600px){.app{padding:16px 14px 60px}.title{font-size:48px}.masthead{padding:20px 0 12px}.masthead-inner{text-align:center;justify-content:center}.masthead-inner>div{text-align:center;width:100%}.toolbar{padding:14px}.view-toggle{margin-left:0}.grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:28px 18px}.caption-name{font-size:22px}.row{grid-template-rows:auto auto;grid-template-columns:60px 1fr}.row-thumb{width:60px;height:60px}.row-meta{text-align:left;grid-column:1/-1}.modal{padding:20px 18px}.sheet-title{font-size:32px}.detail-name{font-size:36px}}
