@font-face{font-family:Barbaro;src:url(/fonts/barbaro.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--bg:#0b0f14;--panel:#111826;--muted:#0d131d;--text:#e7ecf3;--text-dim:#a7b2c3;--brand:#e18f2e;--brand-strong:#c87a1f;--border:hsla(0,0%,100%,.08);--radius:14px;--shadow:0 10px 30px rgba(0,0,0,.25)}*{box-sizing:border-box}body,html{height:100%}body{margin:0;background:var(--bg);color:var(--text);font:14px/1.5 ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:10;background:linear-gradient(0deg,#985b21,#e18f2e);border-bottom:1px solid hsla(0,0%,100%,.1)}.container{max-width:1100px;margin:0 auto;padding:14px 20px}.main{flex:1 1;padding:24px 20px 40px}.nav{display:flex;gap:14px;align-items:center}.nav .brand{font-family:Barbaro,serif;font-weight:400;font-size:20px;letter-spacing:.5px;margin-right:auto;color:#231f20;text-decoration:none}.nav .brand:hover{color:#231f20;background:none;border-color:transparent}.nav-link{color:hsla(0,0%,100%,.85);text-decoration:none;padding:8px 10px;border-radius:10px;border:1px solid transparent;font:inherit;font-size:inherit;cursor:pointer}.nav-link:hover{color:#fff;background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.2)}.nav-link-active{background:hsla(0,0%,100%,.2);color:#fff;border-color:hsla(0,0%,100%,.25);font-weight:700}.nav-logout{background:none;width:auto}.nav .cta{color:#071b18;background:#fff;border-color:transparent;font-weight:600}.nav .cta:hover{background:hsla(0,0%,100%,.9)}.card{background:linear-gradient(180deg,hsla(0,0%,100%,.03),hsla(0,0%,100%,0)),var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.grid{display:grid;grid-gap:14px;gap:14px}.grid.cols-3{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.label{font-size:12px;color:var(--text-dim);margin-bottom:6px}.input,button,select{width:100%;background:var(--muted);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.input::placeholder{color:#7d8aa0}.button{background:var(--brand);color:#071b18;border:none;font-weight:600;cursor:pointer}.button:hover{background:var(--brand-strong)}.thumb{width:100%;aspect-ratio:16/10;background:var(--muted);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb .fallback{color:var(--text-dim);font-size:12px}.hero{position:relative;text-align:center;padding:70px 24px 50px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);background:linear-gradient(180deg,rgba(11,15,20,.72),rgba(11,15,20,.42) 48%,rgba(11,15,20,.86)),url(/images/hero-museum.jpg) center 72% /cover no-repeat}.hero h1{font-size:48px;font-weight:800;letter-spacing:-1px;margin:0;background:linear-gradient(135deg,var(--brand),#f0b96a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero .tagline{color:var(--text-dim);font-size:18px;margin-top:12px}.steps{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;margin-top:24px;max-width:800px;margin-inline:auto}@media(max-width:680px){.steps{grid-template-columns:1fr;max-width:360px}}.step-num{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--brand);color:#071b18;font-weight:700;font-size:14px;margin-bottom:10px}.section-title{font-size:20px;font-weight:700;margin:0 0 4px}.section-sub{color:var(--text-dim);font-size:14px;margin:0}.species-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:14px;gap:14px}.species-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .15s,border-color .15s}.species-card:hover{transform:translateY(-3px);border-color:var(--brand)}.species-card-image{aspect-ratio:5/7;overflow:hidden;background:#1a1a1a}.species-card-image img{width:100%;height:100%;object-fit:contain;display:block}.species-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:12px;text-align:center;padding:12px}.species-card-footer{padding:10px 12px}.rarity-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#071b18;padding:2px 7px;border-radius:6px}.locked-card{cursor:default}.locked-card:hover{transform:none;border-color:var(--border)}.locked-image{position:relative;background:linear-gradient(135deg,#0d131d,#1a2233 50%,#0d131d)}.locked-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:hsla(0,0%,100%,.15)}.species-card.collected{border-color:rgba(225,143,46,.3);box-shadow:0 0 20px rgba(225,143,46,.08)}.species-card.collected:hover{border-color:var(--brand);box-shadow:0 0 24px rgba(225,143,46,.15)}.progress-bar-track{width:100%;height:8px;background:var(--muted);border-radius:4px;overflow:hidden;border:1px solid var(--border)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--brand),#f0b96a);border-radius:4px;transition:width .6s ease}.modal-overlay{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{background:var(--panel);border:1px solid var(--border);border-radius:16px;max-width:680px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:12px;right:12px;z-index:2;width:32px;height:32px;background:rgba(0,0,0,.5);color:var(--text);border:none;border-radius:50%;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:rgba(0,0,0,.8)}.modal-body{display:grid;grid-template-columns:1fr 1fr}@media(max-width:600px){.modal-body{grid-template-columns:1fr}}.modal-card-image{background:var(--muted);display:flex;align-items:center;justify-content:center}.modal-card-image img{width:100%;height:auto;display:block}.modal-stats{padding:24px}.stats-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin-bottom:16px}.stat-item{background:var(--muted);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:2px}.stat-value{font-weight:700;font-size:13px}.stat-pill{display:inline-block;font-size:11px;font-weight:600;color:var(--text);background:var(--muted);border:1px solid var(--border);padding:2px 8px;border-radius:6px}.fun-fact{background:linear-gradient(135deg,rgba(225,143,46,.08),rgba(225,143,46,.02));border:1px solid rgba(225,143,46,.15);border-radius:10px;padding:12px 14px;font-size:13px;color:var(--text-dim);line-height:1.5}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:12px;gap:12px}.achievement-card{display:flex;gap:12px;align-items:flex-start;background:var(--muted);border:1px solid var(--border);border-radius:12px;padding:14px;transition:border-color .2s,box-shadow .2s}.achievement-card.achievement-earned{border-color:rgba(225,143,46,.35);box-shadow:0 0 16px rgba(225,143,46,.08)}.achievement-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.achievement-info{flex:1 1;min-width:0}.achievement-label{font-weight:700;font-size:13px;margin-bottom:2px}.achievement-earned .achievement-label{color:var(--brand)}.achievement-desc{font-size:11px;color:var(--text-dim);line-height:1.4;margin-bottom:8px}.achievement-progress-row{display:flex;align-items:center;gap:8px}.achievement-progress-track{flex:1 1;height:6px;background:var(--panel);border-radius:3px;overflow:hidden;border:1px solid var(--border)}.achievement-progress-fill{height:100%;background:linear-gradient(90deg,var(--brand),#f0b96a);border-radius:3px;transition:width .6s ease}.achievement-progress-text{font-size:11px;font-weight:700;color:var(--text-dim);white-space:nowrap}.achievement-badge-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:9999px;background:var(--panel);border:1px solid rgba(225,143,46,.3);font-size:12px;font-weight:600;color:var(--brand)}.nav-ghost-button{background:transparent;color:var(--text);border:1px solid var(--border);border-radius:10px;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s}.nav-ghost-button:hover{border-color:var(--brand);background:rgba(225,143,46,.08);color:var(--text)}.hero-stats{display:flex;gap:36px;justify-content:center;margin-top:30px}.hero-stats div{display:flex;flex-direction:column;align-items:center}.hero-stats b{font-size:26px;color:var(--brand)}.hero-stats span{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim)}.specimen-of-day{display:flex;gap:22px;align-items:center;flex-wrap:wrap}.specimen-of-day-image{width:180px;flex-shrink:0;border-radius:12px;overflow:hidden;border:1px solid rgba(225,143,46,.25);box-shadow:0 0 24px rgba(225,143,46,.12)}.specimen-of-day-image img{width:100%;display:block}@media(max-width:560px){.specimen-of-day{justify-content:center;text-align:center}.specimen-of-day a{display:inline-block;margin-top:6px}}.feature-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:14px;gap:14px}.feature-link{text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:6px;transition:transform .15s,border-color .15s}.feature-link:hover{transform:translateY(-3px);border-color:var(--brand)}.feature-link p{margin:0;font-size:12px;color:var(--text-dim);line-height:1.5}.museum-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.filter-pills{display:flex;gap:8px}.filter-pill{width:auto;padding:7px 16px;border-radius:9999px;font-size:12px;font-weight:600;background:var(--muted);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:all .15s}.filter-pill:hover{border-color:var(--brand);color:var(--text)}.filter-pill-active{background:var(--brand);border-color:var(--brand);color:#071b18}.hall-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.hall-progress{display:flex;align-items:center;gap:10px;font-size:13px}.hall-complete{border-color:rgba(225,143,46,.45);box-shadow:0 0 28px rgba(225,143,46,.12)}.hall-complete-pill{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:#071b18;background:linear-gradient(135deg,var(--brand),#f0b96a);padding:3px 10px;border-radius:9999px}.silhouette img{filter:grayscale(1) brightness(.22) contrast(1.15) blur(2px);transition:filter .3s}.species-card.pedestal-empty{background:linear-gradient(180deg,#0c1119,#0a0e15);border-style:dashed;border-color:hsla(0,0%,100%,.1)}.species-card.pedestal-empty:hover{border-color:rgba(225,143,46,.5)}.species-card.pedestal-empty:hover .silhouette img{filter:grayscale(1) brightness(.32) contrast(1.15) blur(1px)}.species-card-image{position:relative}.pedestal-number{position:absolute;bottom:8px;right:10px;font-size:11px;font-weight:800;letter-spacing:1px;color:hsla(0,0%,100%,.25)}.modal-card-image.silhouette{background:#0a0e15}.reveal-stage{perspective:1200px;width:min(300px,80vw);aspect-ratio:5/7;margin:0 auto;cursor:pointer}.reveal-card{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .9s cubic-bezier(.2,.7,.25,1.05)}.reveal-stage.is-flipped{cursor:default}.reveal-stage.is-flipped .reveal-card{transform:rotateY(180deg)}.reveal-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:16px;overflow:hidden;border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center}.reveal-back{background:radial-gradient(circle at 50% 35%,rgba(225,143,46,.18),transparent 60%),linear-gradient(160deg,#141b29,#0b0f16);gap:18px;animation:reveal-pulse 2s ease-in-out infinite}.reveal-back img{width:60%;opacity:.9}.reveal-back span{font-size:11px;font-weight:800;letter-spacing:3px;color:var(--brand)}@keyframes reveal-pulse{0%,to{box-shadow:0 0 18px rgba(225,143,46,.15)}50%{box-shadow:0 0 36px rgba(225,143,46,.35)}}.reveal-front{transform:rotateY(180deg);background:#10151f}.reveal-front img{width:100%;height:100%;object-fit:contain}.reveal-stage.is-flipped .reveal-face.reveal-front{box-shadow:0 0 44px var(--glow,var(--brand));border-color:var(--glow,var(--brand))}.reveal-details{animation:reveal-rise .6s ease .25s both}@keyframes reveal-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.rank-card{gap:18px;flex-wrap:wrap}.rank-card,.rank-icon{display:flex;align-items:center}.rank-icon{font-size:42px;width:72px;height:72px;justify-content:center;background:radial-gradient(circle,rgba(225,143,46,.18),transparent 70%);border:1px solid rgba(225,143,46,.3);border-radius:50%;flex-shrink:0}.rank-points{text-align:center}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:14px;gap:14px}.stat-tile{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-decoration:none;color:var(--text);transition:border-color .15s,transform .15s}a.stat-tile:hover{border-color:var(--brand);transform:translateY(-2px)}.stat-tile-value{font-size:24px;font-weight:800;color:var(--brand)}.stat-tile-value small{font-size:14px;color:var(--text-dim);font-weight:600}.stat-tile-label{font-size:11px;color:var(--text-dim);margin-top:4px}.achievement-locked{opacity:.75}.achievement-locked .achievement-icon{filter:grayscale(1) brightness(.7)}.streak-flame{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,rgba(225,143,46,.12),rgba(225,143,46,.03));border:1px solid rgba(225,143,46,.25);border-radius:12px;padding:10px 16px}.journal-stats{grid-template-columns:repeat(3,1fr)}.journal-stats,.quiz-options{display:grid;grid-gap:10px;gap:10px}.quiz-option{text-align:left;background:var(--muted);border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-size:14px;cursor:pointer;transition:border-color .15s,background .15s;color:var(--text)}.quiz-option:hover:not(:disabled){border-color:var(--brand)}.quiz-option:disabled{cursor:default}.quiz-selected{border-color:var(--brand);background:rgba(225,143,46,.1)}.quiz-correct{border-color:#4ade80;background:rgba(74,222,128,.1)}.quiz-wrong{border-color:#f87171;background:hsla(0,91%,71%,.08)}.journal-reveal{display:flex;gap:14px;align-items:flex-start;margin-top:14px;background:var(--muted);border:1px solid var(--border);border-radius:12px;padding:12px}.journal-reveal img{width:90px;border-radius:8px;flex-shrink:0}.leaderboard-row{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:10px;text-decoration:none;color:var(--text);transition:background .15s}.leaderboard-row:hover{background:hsla(0,0%,100%,.04)}.leaderboard-row+.leaderboard-row{border-top:1px solid var(--border)}.leaderboard-top{background:linear-gradient(90deg,rgba(225,143,46,.07),transparent)}.leaderboard-medal{width:34px;text-align:center;font-size:18px;font-weight:800;color:var(--text-dim);flex-shrink:0}.leaderboard-stat{font-size:13px;font-weight:700;text-align:right;min-width:64px}.leaderboard-stat small{display:block;font-size:10px;font-weight:500;color:var(--text-dim)}@media(max-width:520px){.leaderboard-stat{min-width:48px}.leaderboard-stat:nth-of-type(2){display:none}}