.toast{display:flex;align-items:center;gap:12px;padding:12px 20px;margin-bottom:12px;border-radius:8px;box-shadow:0 4px 12px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:280px;max-width:400px;cursor:pointer;opacity:0;transform:translate(100%);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.toast:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:currentColor}.toast-visible{opacity:1;transform:translate(0)}.toast-exiting{opacity:0;transform:translate(100%)}.toast-icon{font-size:20px;font-weight:700;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff3}.toast-message{flex:1;font-size:14px;line-height:1.5;word-break:break-word;white-space:pre-line}.toast-success{background:linear-gradient(135deg,#4caf50f2,#388e3cf2);color:#fff}.toast-error{background:linear-gradient(135deg,#f44336f2,#c62828f2);color:#fff}.toast-warning{background:linear-gradient(135deg,#ffc107f2,#ff9800f2);color:#333}.toast-info{background:linear-gradient(135deg,#2196f3f2,#1976d2f2);color:#fff}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;pointer-events:none}.toast-container .toast{pointer-events:auto}@media (max-width: 768px){.toast-container{top:10px;right:10px;left:10px}.toast{min-width:auto;max-width:100%}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--color-bg-card);border-radius:16px;padding:24px;max-width:400px;width:100%;box-shadow:0 20px 60px #00000080;border:1px solid var(--color-border);animation:slideUp .3s ease-out;position:relative}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-dialog-header{margin-bottom:16px}.confirm-dialog-title{font-size:1.25rem;font-weight:700;margin:0;color:var(--color-text);line-height:1.4}.confirm-dialog-body{margin-bottom:24px}.confirm-dialog-message{font-size:1rem;line-height:1.6;color:var(--color-text-secondary);margin:0}.confirm-dialog-actions{display:flex;gap:12px;justify-content:flex-end}.confirm-dialog-button{padding:10px 24px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;min-width:80px}.confirm-dialog-button-cancel{background:#ffffff1a;color:var(--color-text);border:1px solid var(--color-border)}.confirm-dialog-button-cancel:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-1px)}.confirm-dialog-button-cancel:active{transform:translateY(0)}.confirm-dialog-button-confirm{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-major) 100%);color:#fff;border:none}.confirm-dialog-button-confirm:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e9456066}.confirm-dialog-button-confirm:active{transform:translateY(0)}.confirm-dialog-button-confirm.danger{background:linear-gradient(135deg,#e94560,#c73650)}.confirm-dialog-button-confirm.danger:hover{box-shadow:0 4px 12px #e9456080}.confirm-dialog-button-confirm.warning{background:linear-gradient(135deg,orange,#ff8c00)}.confirm-dialog-button-confirm.warning:hover{box-shadow:0 4px 12px #ffa50066}.confirm-dialog-button-confirm.info{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-major) 100%)}@media (max-width: 768px){.confirm-dialog{padding:20px;max-width:90%}.confirm-dialog-title{font-size:1.1rem}.confirm-dialog-message{font-size:.95rem}.confirm-dialog-actions{flex-direction:column-reverse}.confirm-dialog-button{width:100%}}.route-loading-fallback{display:flex;justify-content:center;align-items:center;min-height:280px;padding:2rem}.route-loading-fallback-inner{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--color-text-secondary, rgba(255, 255, 255, .75))}.route-loading-fallback-spinner{width:40px;height:40px;border:3px solid rgba(233,69,96,.25);border-top-color:var(--color-accent, #e94560);border-radius:50%;animation:loading-fallback-spin .85s linear infinite}.route-loading-fallback-text{font-size:.95rem;letter-spacing:.02em}@keyframes loading-fallback-spin{to{transform:rotate(360deg)}}.app{min-height:100vh;display:flex;flex-direction:column;padding:2rem;max-width:1400px;margin:0 auto;width:100%;position:relative;overflow-x:hidden;box-sizing:border-box}.app:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(255,107,157,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(74,144,226,.1) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(255,165,0,.05) 0%,transparent 50%);pointer-events:none;z-index:-1}.app:after{content:"✨";position:fixed;font-size:2rem;opacity:.1;animation:sparkle 4s ease-in-out infinite;pointer-events:none;z-index:-1}@keyframes sparkle{0%,to{transform:translate(0) scale(1);opacity:.1}25%{transform:translate(100px,100px) scale(1.5);opacity:.2}50%{transform:translate(-50px,200px) scale(.8);opacity:.15}75%{transform:translate(150px,-50px) scale(1.2);opacity:.2}}.app-header{text-align:center;margin-bottom:3rem;padding:2rem 0;position:relative}.category-selector{display:flex;justify-content:center;margin:1.5rem 0;background:transparent!important;padding:0!important;border:none!important;box-shadow:none!important}.category-select{padding:.7rem 3rem .7rem 1.5rem;background:#0f346099!important;border:2px solid rgba(255,255,255,.15)!important;border-radius:25px;color:var(--color-text)!important;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#0f346099!important;background-repeat:no-repeat;background-position:right 1rem center;background-size:12px;min-width:180px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.category-select:hover{background:#0f3460b3!important;border-color:#ffffff40!important}.category-select:focus{outline:none;border-color:var(--color-accent)!important;box-shadow:0 0 0 3px #e9456033;background:#0f3460b3!important}.category-select:active{background:#0f3460b3!important}.category-select option{background:#0f3460f2!important;color:var(--color-text)!important;padding:.5rem;border:none}.carousel-container{position:relative;display:flex;align-items:center;justify-content:center;margin:3rem 0;height:300px;perspective:1000px;touch-action:pan-y;-webkit-overflow-scrolling:touch;cursor:grab;-webkit-user-select:none;user-select:none}.carousel-wrapper{position:relative;width:100%;height:100%;perspective:1000px;transform-style:preserve-3d;overflow:visible;transition:transform .3s ease-out}.carousel-container:active .carousel-wrapper{cursor:grabbing;transition:none}.transition-effect{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;pointer-events:none;z-index:50;overflow:visible}.effect-particles{position:absolute;width:100%;height:100%;top:0;left:0}.particle{position:absolute;width:4px;height:4px;background:radial-gradient(circle,rgba(233,69,96,1) 0%,rgba(74,144,226,.8) 50%,transparent 100%);border-radius:50%;animation:particleFloat .8s ease-out forwards;box-shadow:0 0 8px #e94560cc,0 0 12px #4a90e299;transform:translate(-50%,-50%)}@keyframes particleFloat{0%{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(0)}to{opacity:0;transform:translate(calc(-50% + (var(--random-x, .5) - .5) * 300px),calc(-50% + (var(--random-y, .5) - .5) * 300px)) scale(0) rotate(360deg)}}.effect-light{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200%;height:200%;background:radial-gradient(circle,rgba(233,69,96,.3) 0%,rgba(74,144,226,.2) 30%,transparent 70%);animation:lightPulse .6s ease-out;pointer-events:none}@keyframes lightPulse{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}to{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}.carousel-track.effect-mystic{filter:blur(2px);animation:mysticGlow .6s ease-in-out}@keyframes mysticGlow{0%,to{filter:blur(0px) brightness(1)}50%{filter:blur(3px) brightness(1.3)}}.carousel-track.effect-sparkle{animation:sparkleShine .6s ease-in-out}@keyframes sparkleShine{0%,to{filter:brightness(1) drop-shadow(0 0 0 rgba(233,69,96,0))}50%{filter:brightness(1.4) drop-shadow(0 0 20px rgba(233,69,96,.8))}}.carousel-track.effect-glow{animation:glowPulse .6s ease-in-out}@keyframes glowPulse{0%,to{box-shadow:0 0 #e9456000}50%{box-shadow:0 0 40px #e9456099,0 0 80px #4a90e266}}.carousel-track.effect-fade{animation:fadeTransition .6s ease-in-out}@keyframes fadeTransition{0%,to{opacity:1}50%{opacity:.5}}.carousel-track.effect-swirl{animation:swirlRotate .6s ease-in-out}@keyframes swirlRotate{0%,to{transform:translateZ(-400px) rotateY(var(--carousel-rotation)) scale(1) rotate(0)}50%{transform:translateZ(-410px) rotateY(var(--carousel-rotation)) scale(1.05) rotate(5deg)}}.carousel-track.effect-zoom{animation:zoomTransition .6s ease-in-out}@keyframes zoomTransition{0%{transform:translateZ(-420px) rotateY(var(--carousel-rotation)) scale(.9);filter:blur(2px);opacity:.7}50%{transform:translateZ(-380px) rotateY(var(--carousel-rotation)) scale(1.05);filter:blur(0);opacity:1}to{transform:translateZ(-400px) rotateY(var(--carousel-rotation)) scale(1);filter:blur(0);opacity:1}}.carousel-track.effect-flip{animation:flipTransition .6s ease-in-out}@keyframes flipTransition{0%{transform:translateZ(-400px) rotateY(calc(var(--carousel-rotation) - 45deg));opacity:.4}50%{transform:translateZ(-380px) rotateY(calc(var(--carousel-rotation) + 10deg));opacity:1}to{transform:translateZ(-400px) rotateY(var(--carousel-rotation));opacity:1}}.carousel-track.effect-warp{animation:warpTransition .6s ease-in-out}@keyframes warpTransition{0%{transform:translateZ(-380px) rotateY(var(--carousel-rotation)) skew(8deg);filter:blur(1px)}50%{transform:translateZ(-430px) rotateY(var(--carousel-rotation)) skew(-4deg);filter:blur(2px)}to{transform:translateZ(-400px) rotateY(var(--carousel-rotation)) skew(0);filter:blur(0)}}.carousel-track{position:relative;width:280px;height:180px;margin:0 auto;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);will-change:transform}.carousel-track.no-transition{transition:none}.carousel-item{position:absolute;width:280px;height:180px;transform-style:preserve-3d;cursor:pointer;transition:transform .3s ease;z-index:1;will-change:transform}.carousel-item.center{z-index:100;isolation:isolate;transform-style:preserve-3d}.carousel-item.center .feature-card{transform:scale(1.2);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-major) 100%);border-color:var(--color-accent);box-shadow:0 8px 30px #e9456080;z-index:100;position:relative;isolation:isolate;transform-style:preserve-3d}.carousel-item:not(.center){z-index:1}.carousel-item:not(.center) .feature-card{opacity:.6;filter:blur(2px);z-index:1;position:relative;transform-style:preserve-3d}.carousel-container{cursor:grab;-webkit-user-select:none;user-select:none}.carousel-container:active{cursor:grabbing}.feature-card{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem;background:#0f346066;border:2px solid rgba(255,255,255,.1);border-radius:16px;color:var(--color-text);cursor:pointer;transition:all .3s ease;text-align:center;backface-visibility:hidden}.feature-card:hover{background:#0f346099;border-color:#ffffff4d;transform:translateY(-4px);box-shadow:0 8px 20px #0000004d}.feature-card.active{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-major) 100%);border-color:var(--color-accent);box-shadow:0 6px 20px #e9456066;transform:translateY(-2px)}.feature-icon{font-size:2.5rem;margin-bottom:.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.feature-card.active .feature-icon{filter:drop-shadow(0 2px 8px rgba(255,255,255,.3))}.feature-name{font-size:.9rem;font-weight:600;line-height:1.3}.header-actions{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}.app-header:before{content:"🔮";position:absolute;left:50%;top:-1rem;transform:translate(-50%);font-size:4rem;opacity:.2;animation:floatHeader 3s ease-in-out infinite}@keyframes floatHeader{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-10px)}}.app-header h1{font-size:3.5rem;font-weight:700;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-major) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;text-shadow:0 0 30px rgba(233,69,96,.3)}.subtitle{font-size:1.2rem;color:var(--color-text-secondary);font-weight:300}.app-main{flex:1;display:flex;flex-direction:column;gap:2rem;width:100%;overflow-x:hidden;box-sizing:border-box}.controls{display:flex;justify-content:center;margin-bottom:1rem}.three-card-reading{width:100%;padding:2rem;background:#0f34604d;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);margin-bottom:2rem}.reading-title{text-align:center;font-size:2rem;font-weight:700;margin-bottom:2rem;color:var(--color-text);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-major) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.three-cards-container{display:flex;justify-content:center;align-items:flex-start;gap:2rem;flex-wrap:wrap}.three-card-item{display:flex;flex-direction:column;align-items:center;gap:1rem;flex:1;min-width:280px;max-width:320px}@media (max-width: 1024px) and (min-width: 769px){.three-card-reading{padding:1.5rem}.three-cards-container{gap:1.5rem}.three-card-item{min-width:240px;max-width:280px}}.card-position-label{font-size:1.2rem;font-weight:600;color:var(--color-accent);padding:.5rem 1.5rem;background:#e945601a;border:2px solid var(--color-accent);border-radius:25px;text-align:center;width:fit-content;box-shadow:0 4px 15px #e9456033}.three-card-item .card-display{width:100%;padding:1rem}.three-card-item .card{width:100%;max-width:280px;margin:0 auto}.reading-interpretation{margin-top:3rem;padding:2rem;background:#0f346066;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid var(--color-accent);box-shadow:0 8px 32px #e9456033}.interpretation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.interpretation-title{font-size:1.8rem;font-weight:700;text-align:center;flex:1;color:var(--color-text);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-major) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.export-section{text-align:center;margin-bottom:1rem;display:flex;gap:.5rem;justify-content:center}.action-buttons{display:flex;gap:.5rem}.export-btn,.share-btn{background:linear-gradient(135deg,var(--color-cups) 0%,#5ba3f5 100%);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #4a90e24d}.share-btn{background:linear-gradient(135deg,var(--color-wands) 0%,#ff8c00 100%);box-shadow:0 4px 15px #ffa5004d}.export-btn:hover,.share-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90e266}.share-btn:hover{box-shadow:0 6px 20px #ffa50066}.interpretation-content{display:flex;flex-direction:column;gap:1.5rem}.interpretation-summary{padding:1.5rem;background:#e945601a;border-radius:15px;border-left:4px solid var(--color-accent)}.interpretation-summary h4{font-size:1.2rem;color:var(--color-accent);margin:0 0 .75rem;font-weight:600}.interpretation-summary p{font-size:1rem;line-height:1.8;color:var(--color-text);margin:0}.interpretation-stages{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stage-item{padding:1.5rem;background:#0f346080;border-radius:15px;border:1px solid var(--color-border);transition:all .3s ease}.stage-item:hover{transform:translateY(-5px);box-shadow:0 8px 24px #0000004d;border-color:var(--color-accent)}.stage-item h4{font-size:1.1rem;color:var(--color-accent);margin:0 0 .75rem;font-weight:600}.stage-item p{font-size:.95rem;line-height:1.7;color:var(--color-text);margin:0}.interpretation-advice{padding:1.5rem;background:#ffa5001a;border-radius:15px;border-left:4px solid var(--color-wands)}.interpretation-advice h4{font-size:1.2rem;color:var(--color-wands);margin:0 0 .75rem;font-weight:600}.interpretation-advice p{font-size:1rem;line-height:1.8;color:var(--color-text);margin:0;font-style:italic}.drawn-cards{margin-top:3rem;padding:2rem;background:#0f34604d;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border)}.drawn-cards h2{font-size:1.5rem;margin-bottom:1.5rem;color:var(--color-text);text-align:center}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:1rem}.card-thumbnail{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:12px;padding:1rem;cursor:pointer;transition:all .3s ease;text-align:center}.card-thumbnail:hover{transform:translateY(-5px);border-color:var(--color-accent);box-shadow:var(--shadow-hover)}.card-thumbnail.selected{border-color:var(--color-accent);box-shadow:0 0 20px #e9456080;background:#e945601a}.card-thumbnail-content{display:flex;flex-direction:column;gap:.5rem;align-items:center;position:relative}.card-thumbnail-icon{font-size:2rem;margin-bottom:.25rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:transform .3s ease}.card-thumbnail:hover .card-thumbnail-icon{transform:scale(1.2) rotate(5deg)}.card-thumbnail-name{font-size:.9rem;font-weight:600;color:var(--color-text);text-align:center;line-height:1.3}.card-thumbnail-suit{position:absolute;top:.5rem;right:.5rem;font-size:.8rem;opacity:.6}.card-thumbnail-type{font-size:.75rem;color:var(--color-text-secondary)}.reversed-indicator{font-size:.7rem;color:var(--color-accent);margin-left:.3rem;font-weight:600}.app-footer{text-align:center;padding:2rem 0;margin-top:3rem;color:var(--color-text-secondary);font-size:.9rem;border-top:1px solid var(--color-border)}.footer-content{display:flex;flex-direction:column;gap:1rem;align-items:center}.footer-copyright{margin:0;color:var(--color-text-secondary);font-size:.9rem}.footer-team{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-top:.5rem}.team-label{margin:0;font-size:.85rem;color:var(--color-text-secondary);opacity:.8}.team-name{margin:0;font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-major) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:2px}.footer-contact{margin-top:.5rem}.contact-email{display:inline-flex;align-items:center;gap:.5rem;color:var(--color-text-secondary);text-decoration:none;font-size:.9rem;padding:.5rem 1rem;border-radius:8px;transition:all .3s ease;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.contact-email:hover{color:var(--color-accent);background:#ffffff1a;border-color:var(--color-accent);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.contact-email:active{transform:translateY(0)}@media (max-width: 1024px) and (min-width: 769px){.app{padding:1.5rem}.app-header h1{font-size:3rem}.three-cards-container{gap:1.5rem}.three-card-item{min-width:250px;max-width:300px}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}@media (max-width: 768px){.app{padding:1rem}.app-header{margin-bottom:2rem;padding:1.5rem 0}.app-header:before{font-size:3rem;top:-.5rem}.app-header h1{font-size:2rem;margin-bottom:.5rem}.subtitle{font-size:1rem}.category-selector{margin:1rem 0}.category-select{padding:.6rem 2.5rem .6rem 1.2rem;font-size:.9rem;min-width:160px}.carousel-container{height:250px;margin:2rem 0;display:flex;align-items:center;justify-content:center}.carousel-wrapper{width:100%;display:flex;align-items:center;justify-content:center}.carousel-track{width:220px;height:140px;margin:0 auto}.carousel-item{width:220px;height:140px}.transition-effect{width:220px;height:140px;left:50%;top:50%;transform:translate(-50%,-50%)}.particle{width:3px;height:3px;--particle-distance: 200px}.effect-light{width:150%;height:150%}.feature-card{padding:1rem .5rem}.feature-icon{font-size:2rem;margin-bottom:.4rem}.feature-name{font-size:.8rem}.header-actions{margin-top:1rem;gap:.5rem}.header-actions button{font-size:.85rem;padding:.6rem 1.2rem}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem}.three-cards-container{flex-direction:column;gap:1.5rem}.three-card-item{min-width:100%;max-width:100%}.reading-title{font-size:1.5rem}.interpretation-stages{grid-template-columns:1fr}.interpretation-title{font-size:1.5rem}.reading-interpretation,.drawn-cards{padding:1.5rem;margin-top:2rem}.drawn-cards h2{font-size:1.3rem;margin-bottom:1rem}.card-thumbnail{padding:.75rem}.card-thumbnail-icon{font-size:1.5rem}.card-thumbnail-name{font-size:.8rem}.export-section{flex-direction:column;gap:.75rem}.export-btn,.share-btn{width:100%;padding:.85rem 1.5rem}}@media (max-width: 480px){.app{padding:.75rem}.category-selector{margin:.8rem 0}.category-select{padding:.5rem 2.2rem .5rem 1rem;font-size:.85rem;min-width:140px}.carousel-container{height:200px;margin:1.5rem 0;display:flex;align-items:center;justify-content:center}.carousel-wrapper{width:100%;display:flex;align-items:center;justify-content:center}.carousel-track{width:180px;height:110px;margin:0 auto}.carousel-item{width:180px;height:110px}.transition-effect{width:180px;height:110px;left:50%;top:50%;transform:translate(-50%,-50%)}.particle{width:2px;height:2px;--particle-distance: 150px}.effect-light{width:120%;height:120%}.carousel-nav{width:35px;height:35px;font-size:1.2rem}.carousel-nav-left{left:.5rem}.carousel-nav-right{right:.5rem}.feature-card{padding:.8rem .4rem}.feature-icon{font-size:1.5rem;margin-bottom:.3rem}.feature-name{font-size:.7rem}.app-header{margin-bottom:1.5rem;padding:1rem 0}.app-header h1{font-size:1.75rem}.subtitle{font-size:.9rem}.header-nav{display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem;width:100%}.nav-btn{width:100%;font-size:.8rem;padding:.5rem .8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions{flex-direction:column;width:100%;gap:.5rem}.header-actions button{width:100%;font-size:.8rem;padding:.7rem 1rem}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}.card-thumbnail{padding:.5rem}.card-thumbnail-icon{font-size:1.3rem}.card-thumbnail-name{font-size:.75rem}.card-thumbnail-type{font-size:.7rem}.drawn-cards{padding:1rem}.drawn-cards h2{font-size:1.2rem}.three-card-reading{padding:1rem}.reading-title{font-size:1.3rem}.card-position-label{font-size:1rem;padding:.4rem 1.2rem}.reading-interpretation{padding:1rem}.interpretation-title{font-size:1.3rem;margin-bottom:1.5rem}.interpretation-summary,.stat-detail-card,.stage-item{padding:1rem}.footer-content{gap:.75rem}.footer-copyright{font-size:.85rem}.team-name{font-size:1rem}.contact-email{font-size:.85rem;padding:.4rem .8rem}}.loading-fallback{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.2rem;color:#666;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.weather-toggle-btn{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:50%;width:40px;height:40px;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0;margin:0;padding:0;vertical-align:middle}.weather-toggle-btn:hover{background:#fff3;border-color:#fff6;transform:scale(1.1) rotate(15deg);box-shadow:0 0 15px #87cefa80}.weather-toggle-btn:active{transform:scale(.95) rotate(-15deg)}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.error-boundary-content{max-width:600px;width:100%;text-align:center;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:40px;box-shadow:0 8px 32px #0000004d}.error-icon{font-size:64px;margin-bottom:20px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.error-title{font-size:32px;margin:0 0 16px;font-weight:700}.error-message{font-size:18px;margin:0 0 24px;opacity:.9;line-height:1.6}.error-details{margin:24px 0;text-align:left;background:#0000004d;border-radius:8px;padding:16px}.error-details summary{cursor:pointer;font-weight:700;margin-bottom:12px;-webkit-user-select:none;user-select:none}.error-details summary:hover{opacity:.8}.error-stack{font-family:Courier New,monospace;font-size:12px;white-space:pre-wrap;word-break:break-all;margin:0;padding:12px;background:#00000080;border-radius:4px;overflow-x:auto;max-height:300px;overflow-y:auto}.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.error-button{padding:12px 24px;font-size:16px;border:none;border-radius:8px;cursor:pointer;font-weight:700;transition:all .3s ease;min-width:120px}.error-button-primary{background:#fff;color:#667eea}.error-button-primary:hover{background:#f0f0f0;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.error-button-primary:active{transform:translateY(0)}.error-button-secondary{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3)}.error-button-secondary:hover{background:#ffffff4d;border-color:#ffffff80}.error-button-secondary:active{background:#fff3}@media (max-width: 768px){.error-boundary-content{padding:24px}.error-title{font-size:24px}.error-message{font-size:16px}.error-actions{flex-direction:column}.error-button{width:100%}}:root{--color-bg: #1a1a2e;--color-bg-secondary: #16213e;--color-bg-card: #0f3460;--color-text: #eaeaea;--color-text-secondary: #a0a0a0;--color-accent: #e94560;--color-major: #ff6b9d;--color-wands: #ffa500;--color-cups: #4a90e2;--color-swords: #c0c0c0;--color-pentacles: #d4af37;--color-border: rgba(255, 255, 255, .1);--shadow: 0 8px 32px rgba(0, 0, 0, .3);--shadow-hover: 0 12px 48px rgba(0, 0, 0, .4)}*{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden;width:100%;position:relative}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%),radial-gradient(circle at top left,rgba(255,107,157,.1) 0%,transparent 50%),radial-gradient(circle at bottom right,rgba(74,144,226,.1) 0%,transparent 50%);background-attachment:fixed;color:var(--color-text);min-height:100vh;line-height:1.6;position:relative;overflow-x:hidden;width:100%;-webkit-tap-highlight-color:transparent;touch-action:pan-y pinch-zoom;-webkit-overflow-scrolling:touch}@media (max-width: 768px){body{font-size:14px}}@media (max-width: 480px){body{font-size:13px}}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.3),transparent),radial-gradient(2px 2px at 60% 70%,rgba(255,255,255,.2),transparent),radial-gradient(1px 1px at 50% 50%,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 80% 10%,rgba(255,255,255,.2),transparent),radial-gradient(2px 2px at 90% 40%,rgba(255,255,255,.2),transparent),radial-gradient(1px 1px at 33% 60%,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 66% 80%,rgba(255,255,255,.2),transparent);background-size:200% 200%;background-position:0% 0%;animation:starfield 20s linear infinite;pointer-events:none;z-index:0}@keyframes starfield{0%{background-position:0% 0%}to{background-position:100% 100%}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1;width:100%;overflow-x:hidden}
