:root{--charcoal: #1A1A2E;--charcoal-soft: #2A2A3E;--gold: #C8A84B;--gold-light: #E8C870;--gold-dark: #A8852E;--ivory: #F5F0E8;--ivory-dark: #E8E0D0;--cream: #FAF7F0;--text: #1A1A2E;--text-muted: #888;--card-shadow: 0 8px 32px rgba(0,0,0,.12);--card-shadow-hover: 0 12px 48px rgba(0,0,0,.2);--radius: 16px;--transition: .3s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:Inter,sans-serif;background:var(--cream);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;background:linear-gradient(180deg,var(--cream) 0%,var(--ivory) 40%,#EDE5D6 100%)}.header{width:100%;padding:24px 20px 16px;text-align:center;position:relative}.header:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:80px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}.logo-icon{display:inline-flex;align-items:center;justify-content:center;margin-bottom:4px}.logo-icon svg{width:48px;height:48px}.brand-name{font-family:Cormorant Garamond,Georgia,serif;font-size:28px;font-weight:700;color:var(--charcoal);letter-spacing:6px;line-height:1}.brand-elite{font-family:Cormorant Garamond,Georgia,serif;font-size:14px;font-style:italic;color:var(--gold-dark);letter-spacing:8px;display:block;margin-top:2px}.game-container{flex:1;width:100%;max-width:820px;padding:20px;display:flex;flex-direction:column;align-items:center}.loom-section{width:100%;margin-bottom:24px}.loom-label{font-family:Cormorant Garamond,Georgia,serif;font-size:14px;font-style:italic;color:var(--text-muted);letter-spacing:3px;text-align:center;margin-bottom:8px}.loom{width:100%;height:48px;background:var(--ivory-dark);border-radius:12px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000000f}.loom-fill{height:100%;border-radius:12px;background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold-light));transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;min-width:0}.loom-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loom-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:Cormorant Garamond,Georgia,serif;font-size:14px;font-weight:600;color:var(--charcoal);letter-spacing:2px;mix-blend-mode:overlay}.stats{display:flex;justify-content:center;gap:32px;margin-bottom:24px;width:100%}.stat{text-align:center}.stat-value{font-family:Cormorant Garamond,Georgia,serif;font-size:24px;font-weight:700;color:var(--charcoal);line-height:1}.stat-label{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-top:2px}.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;width:100%;max-width:500px;margin:0 auto;perspective:800px}.card{aspect-ratio:1;border-radius:var(--radius);cursor:pointer;position:relative;transition:transform var(--transition),box-shadow var(--transition);transform-style:preserve-3d}.card:hover:not(.matched):not(.disabled){transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.card-inner{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);transition:transform .5s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.card.flipped .card-inner{transform:rotateY(180deg)}.card-face{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;backface-visibility:hidden;-webkit-backface-visibility:hidden}.card-back{background:linear-gradient(135deg,var(--charcoal),var(--charcoal-soft));border:2px solid var(--gold-dark);box-shadow:var(--card-shadow)}.card-back-pattern{width:60%;height:60%;opacity:.3}.card-back-pattern svg{width:100%;height:100%}.card-front{background:#fff;border:2px solid var(--ivory-dark);transform:rotateY(180deg);box-shadow:var(--card-shadow)}.card-front svg{width:55%;height:55%}.card.matched{cursor:default}.card.matched .card-front{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold),0 4px 16px #c8a84b4d}.card.matched .card-inner{animation:pulse-match .6s ease}@keyframes pulse-match{0%{transform:rotateY(180deg) scale(1)}50%{transform:rotateY(180deg) scale(1.08)}to{transform:rotateY(180deg) scale(1)}}.card.disabled{cursor:default;pointer-events:none}.win-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a2ed9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.win-card{background:var(--cream);border-radius:24px;padding:48px 40px 40px;text-align:center;max-width:420px;width:90%;box-shadow:0 24px 80px #0000004d;animation:slideUp .6s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.win-icon{width:64px;height:64px;margin:0 auto 20px}.win-icon svg{width:100%;height:100%}.win-title{font-family:Cormorant Garamond,Georgia,serif;font-size:32px;font-weight:700;color:var(--charcoal);margin-bottom:8px}.win-sub{font-family:Cormorant Garamond,Georgia,serif;font-size:16px;font-style:italic;color:var(--gold-dark);letter-spacing:4px;margin-bottom:16px}.win-detail{font-size:14px;color:var(--text-muted);margin-bottom:8px;line-height:1.6}.win-btn{margin-top:24px;padding:14px 40px;border:none;border-radius:40px;background:linear-gradient(135deg,var(--gold-dark),var(--gold),var(--gold-light));color:var(--charcoal);font-family:Inter,sans-serif;font-size:14px;font-weight:600;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;box-shadow:0 4px 16px #c8a84b4d}.win-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #c8a84b66}.instructions{text-align:center;margin-bottom:20px}.instructions p{font-family:Cormorant Garamond,Georgia,serif;font-size:16px;font-style:italic;color:var(--text-muted);letter-spacing:1px}.footer{width:100%;padding:20px;text-align:center}.footer-text{font-size:11px;color:var(--text-muted);letter-spacing:2px}.footer-text span{color:var(--gold-dark)}@media (max-width: 500px){.card-grid{gap:8px;max-width:100%}.brand-name{font-size:22px;letter-spacing:4px}.stats{gap:20px}.win-card{padding:32px 24px}.win-title{font-size:26px}.header{padding:16px 16px 12px}.game-container{padding:12px}}
