@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;700&family=Inter:wght@300;400;500&display=swap";:root{--background: #FFFFFF;--surface: #F3F4F6;--surface-strong: #E5E7EB;--surface-soft: #F9FAFB;--primary: #EF4444;--primary-strong: #B91C1C;--accent: #2563EB;--accent-soft: #3B82F6;--highlight: #22C55E;--glow: #F97316;--sunshine: #FACC15;--white: #FFFFFF;--black: #0F172A;--text-primary: #111827;--text-secondary: #374151;font-family:Playfair Display,Georgia,Times New Roman,serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--touch-target-min: 44px}html{scroll-behavior:smooth;-webkit-tap-highlight-color:rgba(37,99,235,.35)}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--background);color:var(--text-primary);-webkit-overflow-scrolling:touch;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Playfair Display,serif;line-height:1.2;margin:0 0 1rem;color:var(--text-primary)}p{font-family:Inter,sans-serif;line-height:1.7;margin:0 0 1rem;color:var(--text-secondary)}button{border-radius:25px;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all .3s ease;min-height:var(--touch-target-min);position:relative;overflow:hidden;background-color:var(--primary);color:var(--white);touch-action:manipulation;-webkit-appearance:none}button:focus{outline:2px solid var(--accent);outline-offset:2px}button:hover{background-color:var(--primary-strong);transform:translateY(-1px)}a{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem 1.25rem;border-radius:999px;border:2px solid var(--surface-strong);background-color:var(--surface-soft);color:var(--text-secondary);text-decoration:none;font-weight:600;transition:background-color .3s ease,color .3s ease,border-color .3s ease,transform .2s ease}a:hover{background-color:var(--accent);border-color:var(--accent);color:var(--white);transform:translateY(-1px)}a:focus-visible{outline:3px solid var(--black);outline-offset:3px}@viewport{width:device-width;zoom:1}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (max-width: 768px){:root{font-size:16px}body{line-height:1.5}button{min-height:48px;padding:1rem 1.5rem;font-size:1.1rem}}@media (max-width: 480px){:root{font-size:15px}h1{font-size:2.2rem}h2{font-size:1.8rem}h3{font-size:1.5rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;background-color:var(--background);min-height:100vh;color:var(--text-primary);line-height:1.6;position:relative;overflow-x:hidden}.app{min-height:100vh;position:relative;z-index:1;background-color:var(--background)}.landing-page{margin:0 auto;text-align:center;background-color:var(--background);padding:2rem;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.header{margin-bottom:3rem}.title{font-size:clamp(2.5rem,8vw,3.7rem);color:var(--text-primary);margin-bottom:1rem;font-weight:600;letter-spacing:1.5px;font-family:Playfair Display,serif}.subtitle{font-size:clamp(1.1rem,3vw,1.4rem);color:var(--text-secondary);font-style:italic;font-family:Playfair Display,serif;max-width:600px}.stories-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:2rem;margin:0 auto 3rem;max-width:900px;width:100%;padding:2rem;justify-items:center;align-items:center}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:var(--text-secondary);font-style:italic;font-family:Playfair Display,serif;display:flex;flex-direction:column;align-items:center;gap:1rem;background:#2563eb0f;border-radius:24px;animation:fadeInOut 2s ease-in-out infinite alternate}@keyframes fadeInOut{0%{opacity:.75;transform:scale(.98)}to{opacity:1;transform:scale(1.02)}}.loading:after{content:"💕";font-size:2rem;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.story-card{background-color:var(--white);border:3px solid var(--accent);border-radius:20px;padding:2rem;cursor:pointer;position:relative;aspect-ratio:.75;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;overflow:hidden;color:var(--text-primary)}.story-card.fire-element{background-color:var(--primary);border-color:var(--primary-strong);color:var(--white)}.story-card.water-element{background-color:var(--accent);border-color:var(--accent-soft);color:var(--white)}.story-card.air-element{background-color:var(--sunshine);border-color:var(--glow);color:var(--black)}.story-card.earth-element{background-color:var(--highlight);border-color:var(--primary);color:var(--black)}.story-card.available:hover{transform:translateY(-8px) scale(1.02)}.story-card.available:not(.fire-element):not(.water-element):not(.air-element):not(.earth-element){background-color:var(--surface)}.story-card.available:active{transform:translateY(-4px) scale(.99);transition:all .1s ease}.story-card.available:hover .story-title{transform:translateY(-2px)}.story-card.available:hover .story-description{opacity:1;transform:translateY(-1px)}.story-card.available:hover .read-prompt{opacity:1;transform:scale(1.05)}.story-card.locked{opacity:.55;cursor:not-allowed;background-color:var(--surface-soft);border:2px dashed rgba(37,99,235,.35)}.story-card.active{border:2px solid var(--accent);background-color:var(--accent);color:var(--white)}.story-card.completed{opacity:.95;border:2px solid var(--highlight);background-color:#22c55e1f;color:var(--black)}.completed-info,.active-info{color:var(--text-secondary);font-size:.9rem;font-family:Inter,sans-serif;font-weight:600}.story-title{font-size:clamp(1.2rem,3vw,1.6rem);color:currentColor;margin-bottom:.5rem;font-weight:600;font-family:Playfair Display,serif;letter-spacing:1.5px;text-transform:uppercase;transition:all .3s ease}.story-description{color:currentColor;margin-bottom:.8rem;font-style:italic;font-size:clamp(.85rem,2vw,1rem);opacity:.85;font-family:Inter,sans-serif;line-height:1.5;transition:all .3s ease}.lock-info{text-align:center}.lock-icon{font-size:2rem;margin-bottom:.5rem;opacity:.6}.timer{font-size:.85rem;color:var(--text-secondary);font-weight:500;background:#2563eb14;padding:.5rem 1.1rem;border:1px solid rgba(37,99,235,.35);border-radius:20px;display:inline-block;font-family:Inter,sans-serif;text-align:center;opacity:.95}.read-prompt{font-weight:600;color:var(--accent);font-size:clamp(.9rem,2.5vw,1.05rem);text-transform:uppercase;letter-spacing:1.2px;opacity:.95;transition:all .3s ease}.footer{margin-top:2rem}.love-note{color:var(--text-secondary);font-style:italic;font-size:1rem;opacity:.85}.reset-button{margin-top:1rem;padding:.75rem 1.5rem;background-color:var(--highlight);color:var(--black);border:none;cursor:pointer;font-size:.95rem;font-family:Inter,sans-serif;font-weight:600;min-height:var(--touch-target-min);border-radius:40px}.reset-button:hover{transform:translateY(-2px)}.reset-button:active{transform:translateY(0)}.game-section{margin:1.5rem 0;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.game-button,.qr-button{background-color:var(--accent);color:var(--white);border:none;border-radius:50px;padding:1rem 2.4rem;font-size:1.1rem;font-family:Inter,sans-serif;font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.25,.8,.25,1);animation:gentleBounce 2s ease-in-out infinite}@keyframes gentleBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.game-button:hover,.qr-button:hover{transform:translateY(-8px) scale(1.05) rotate(-1deg);animation:none}.firebase-status{margin-top:1rem}.status{font-size:.9rem;padding:.5rem 1rem;border-radius:20px;font-family:Inter,sans-serif;display:inline-block}.status.testing{color:var(--text-secondary);border:1px solid rgba(250,204,21,.5);background:#facc1526}.status.connected{color:var(--white);border:1px solid rgba(37,99,235,.5);background:#2563eb73}.status.disconnected{color:var(--white);border:1px solid rgba(239,68,68,.45);background:#ef4444a6;opacity:.95}.story-page{width:100vw;height:100vh;position:fixed;top:0;left:0;overflow-y:auto;background-color:var(--background)}.story-page.fire-element{background-color:var(--primary);color:var(--white)}.story-page.water-element{background-color:var(--accent);color:var(--white)}.story-page.air-element{background-color:var(--surface-strong);color:var(--black)}.story-page.earth-element{background-color:var(--highlight);color:var(--black)}.story-header{margin-bottom:2rem;position:relative;z-index:10;padding:2rem}.back-button{background-color:var(--accent);color:var(--white);border:none;border-radius:50px;padding:1rem 2rem;cursor:pointer;font-size:clamp(1rem,2.5vw,1.1rem);font-family:Inter,sans-serif;font-weight:600;min-height:var(--touch-target-min);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;transition:all .4s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}.back-button:hover{transform:translateY(-3px) scale(1.03)}.back-button:active{transform:translateY(0) scale(.99)}.story-content{background-color:var(--white);border:3px solid var(--accent);border-radius:24px;padding:clamp(2rem,6vw,4rem);max-width:800px;word-wrap:break-word;position:relative;z-index:10;color:var(--text-primary)}.story-content.visible{opacity:1}.story-content .story-title{font-size:2.5rem;color:currentColor;margin-bottom:2rem;font-weight:600;letter-spacing:1.5px;font-family:Playfair Display,serif;text-transform:uppercase}.story-text{font-size:clamp(1.1rem,2.5vw,1.2rem);line-height:1.8;color:var(--text-secondary);text-align:left;font-family:Inter,sans-serif;letter-spacing:.3px}.story-paragraph{margin-bottom:3rem;text-indent:2rem}.story-footer{text-align:center;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(37,99,235,.2)}.next-story-hint{color:var(--text-secondary);font-style:italic;font-size:1rem;opacity:.85}@media (max-width: 768px){.landing-page{padding:1rem;justify-content:flex-start;min-height:auto}.stories-grid{grid-template-columns:1fr;grid-template-rows:auto;gap:1.5rem;max-width:400px;padding:1rem}.story-card{padding:1rem;aspect-ratio:1.2;min-height:200px;width:100%}.story-title{font-size:1.2rem;margin-bottom:.5rem}.story-description{font-size:.9rem;line-height:1.4}.timer{padding:.5rem .8rem;font-size:.8rem;min-width:80px}}@media (max-width: 480px){.stories-grid{grid-template-columns:1fr;grid-template-rows:auto;gap:1rem;max-width:350px;padding:.5rem}.story-card{padding:.8rem;aspect-ratio:1.2;min-height:150px;width:100%}.story-title{font-size:1rem}.story-description{font-size:.8rem}}@media (pointer: coarse){.story-card.available{cursor:pointer}button{min-height:48px}}.stories-grid .story-card{opacity:1}.reading-progress{position:fixed;top:0;left:0;height:3px;background:var(--white);z-index:1000}.reading-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--black);font-size:.9rem;color:var(--white);font-style:italic;border:1px solid var(--white)}.story-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.story-paragraph{opacity:1}.story-navigation{margin-top:2rem;text-align:center}.nav-button{background:var(--black);color:var(--white);border:2px solid var(--white);border-radius:50px;padding:1.2rem 2.5rem;font-size:1rem;font-family:Inter,sans-serif;font-weight:500;cursor:pointer;min-height:var(--touch-target-min);display:inline-flex;align-items:center;justify-content:center;transition:all .4s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}.nav-button:hover{background:var(--white);color:var(--black);transform:translateY(-3px) scale(1.05)}.nav-button:active{transform:translateY(-1px) scale(1.01);transition-duration:.1s}@media (max-width: 768px){.story-header{position:sticky;top:0;background:var(--black);padding:1rem;margin:-2rem -2rem 2rem;border-bottom:1px solid var(--white);z-index:100}.reading-indicator{font-size:.8rem;padding:.4rem .8rem}.story-paragraph{font-size:clamp(1.1rem,3vw,1.2rem);line-height:1.8;margin-bottom:1.5rem}.nav-button{width:100%;max-width:300px;padding:1.2rem 2rem;font-size:1.1rem}}@media (max-width: 480px){.story-header{flex-direction:column;align-items:stretch;gap:.5rem}.reading-indicator{align-self:center}.story-paragraph{text-indent:clamp(1rem,5vw,2rem)}}.flappy-game{width:100%;min-height:100vh;margin:0;padding:0;background-color:#4caf50;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.game-header{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.game-title{font-size:clamp(2rem,6vw,3rem);color:var(--text-primary);font-weight:600;letter-spacing:1.5px;font-family:Playfair Display,serif}.game-layout{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.game-container{position:relative;display:flex;align-items:center;justify-content:center;width:min(100vw,calc(100vh * (2 / 3)));height:min(100vh,150vw)}.game-canvas{width:100%;height:100%;border:3px solid rgba(37,99,235,.4);border-radius:20px;background-color:#4caf50;cursor:pointer;transition:all .3s ease;box-shadow:0 20px 60px #00000059}.game-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000e6;border:2px solid var(--white);border-radius:20px;padding:2rem;text-align:center;color:var(--white);font-family:Inter,sans-serif;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.menu-overlay h2,.gameover-overlay h2{font-family:Playfair Display,serif;font-size:2rem;margin-bottom:1rem;color:var(--white)}.menu-overlay p,.gameover-overlay p{margin-bottom:1rem;color:var(--white);opacity:.9}.start-button,.restart-button{background:var(--black);color:var(--white);border:2px solid var(--white);border-radius:50px;padding:1rem 2rem;font-size:1.1rem;font-family:Inter,sans-serif;font-weight:500;cursor:pointer;transition:all .4s cubic-bezier(.25,.8,.25,1)}.start-button:hover,.restart-button:hover{background:var(--white);color:var(--black);transform:translateY(-2px) scale(1.05)}.game-ui{position:absolute;top:24px;left:24px;right:24px;display:flex;justify-content:space-between;align-items:center;z-index:10;pointer-events:none}.score-display,.best-score,.difficulty-display{background:#000c;color:var(--white);padding:.5rem 1rem;border-radius:20px;font-family:Inter,sans-serif;font-weight:500;border:1px solid var(--white);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}@media (max-width: 1024px){.game-layout{flex-direction:column;align-items:center}}@media (max-width: 768px){.game-header{flex-direction:column;gap:1rem;text-align:center}.game-ui{top:16px;left:16px;right:16px}.game-overlay{padding:1.5rem;width:90%}}@media (max-width: 480px){.game-overlay{padding:1rem}.game-ui{top:10px;left:10px;right:10px;flex-wrap:wrap;gap:.5rem}.score-display,.best-score,.difficulty-display{padding:.4rem .8rem;font-size:.8rem}}.qr-generator{max-width:1200px;margin:0 auto;padding:2rem;background-color:var(--surface-soft);min-height:100vh;display:flex;flex-direction:column;align-items:center}.qr-header{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.qr-title{font-size:clamp(2rem,6vw,3rem);color:var(--text-primary);font-weight:600;letter-spacing:1.5px;font-family:Playfair Display,serif}.qr-content{width:100%;max-width:600px;display:flex;flex-direction:column;align-items:center;gap:2rem}.qr-input-section{width:100%;text-align:center}.qr-label{display:block;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:1.1rem;margin-bottom:1rem;font-weight:600}.qr-input{width:100%;max-width:400px;padding:1rem 1.5rem;background:#2563eb14;color:var(--text-primary);border:2px solid rgba(37,99,235,.35);border-radius:25px;font-size:1rem;font-family:Inter,sans-serif;text-align:center;transition:all .3s ease}.qr-input:focus{outline:none;border-color:var(--accent);animation:loveFocus .5s ease}@keyframes loveFocus{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.qr-input.invalid{border-color:var(--primary)}.qr-input::placeholder{color:#0f172a66}.error-message{color:var(--primary);font-family:Inter,sans-serif;font-size:.9rem;margin-top:.5rem}.qr-display-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.qr-preview{background:#2563eb14;padding:1rem;border-radius:20px;max-width:280px;animation:qrAppear .5s ease-out;transition:transform .3s ease}.qr-preview:hover{transform:scale(1.05) rotate(2deg)}@keyframes qrAppear{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.download-button{background-color:var(--accent);color:var(--white);border:none;border-radius:50px;padding:1rem 2rem;font-size:1.1rem;font-family:Inter,sans-serif;font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.25,.8,.25,1)}.download-button:hover{transform:translateY(-2px) scale(1.05)}.qr-info{text-align:center;color:var(--text-secondary);font-family:Inter,sans-serif}.qr-info p{margin-bottom:.5rem;opacity:.85}.qr-info strong{font-weight:600}.qr-placeholder{display:flex;align-items:center;justify-content:center;width:280px;height:280px;border:2px dashed rgba(37,99,235,.4);border-radius:20px;background:#2563eb0d;animation:placeholderPulse 2s ease-in-out infinite alternate}@keyframes placeholderPulse{0%{border-color:#2563eb40;background:#2563eb0d}to{border-color:#2563eb73;background:#2563eb1a}}.placeholder-content{text-align:center;color:var(--white);font-family:Inter,sans-serif}.placeholder-content h3{font-family:Playfair Display,serif;margin-bottom:.5rem;opacity:.8}.placeholder-content p{opacity:.6;font-size:.9rem}@media (max-width: 768px){.qr-generator{padding:1rem}.qr-header{flex-direction:column;gap:1rem;text-align:center}.qr-content,.qr-input{max-width:100%}.qr-preview{max-width:250px}.qr-placeholder{width:250px;height:250px}}.countdown-container{display:flex;flex-direction:column;align-items:center;gap:3rem;text-align:center;padding:2rem}.countdown-message h2{font-size:clamp(2rem,6vw,3rem);color:var(--white);font-family:Playfair Display,serif;margin-bottom:1rem;animation:loveGlow 3s ease-in-out infinite alternate}.countdown-message p{font-size:clamp(1.1rem,3vw,1.4rem);color:var(--white);font-family:Inter,sans-serif;font-style:italic;opacity:.9}@keyframes loveGlow{}.countdown-timer{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;justify-content:center}.countdown-item{display:flex;flex-direction:column;align-items:center;min-width:100px}.countdown-number{font-size:clamp(3rem,8vw,5rem);font-weight:700;color:var(--white);font-family:Playfair Display,serif;animation:countdownPulse 1s ease-in-out infinite alternate}@keyframes countdownPulse{0%{transform:scale(1)}to{transform:scale(1.05)}}.countdown-label{font-size:1rem;color:var(--white);font-family:Inter,sans-serif;text-transform:uppercase;letter-spacing:2px;margin-top:.5rem;opacity:.8;font-weight:500}.countdown-separator{font-size:2rem;animation:heartBeat 1.5s ease-in-out infinite}@keyframes heartBeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.countdown-footer{margin-top:2rem}.countdown-footer p{color:var(--white);font-family:Inter,sans-serif;font-size:1.1rem;margin-bottom:1rem;opacity:.9;animation:gentleFloat 3s ease-in-out infinite alternate}@keyframes gentleFloat{0%{transform:translateY(0)}to{transform:translateY(-5px)}}@media (max-width: 768px){.countdown-container{gap:2rem;padding:1rem}.countdown-timer{gap:1rem}.countdown-item{min-width:80px}.countdown-separator{font-size:1.5rem}}@media (max-width: 480px){.countdown-timer{gap:.5rem}.countdown-item{min-width:60px}.countdown-number{font-size:2.5rem}.countdown-label{font-size:.8rem}}.pacman-game{min-height:100vh;padding:2rem 1rem clamp(7rem,12vw,9rem);display:flex;flex-direction:column;align-items:center;background:radial-gradient(circle at top,#1c1f3d,#0b0d17);color:#f8f9ff;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.pacman-hud{width:min(680px,100%);display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem}.pacman-hud .score,.pacman-hud .lives,.pacman-hud .pellets,.pacman-hud .high-score{background:#0c0f23cc;border:1px solid rgba(91,99,229,.45);border-radius:12px;padding:.75rem 1rem;box-shadow:0 8px 18px #13173a59;display:flex;align-items:center;justify-content:center;gap:.35rem}.life-icons{display:inline-flex;gap:.4rem;margin-left:.4rem}.life{width:16px;height:16px;border-radius:50%;background:radial-gradient(circle at 28% 28%,rgba(255,255,255,.85) 0 16%,transparent 17%),radial-gradient(circle at 70% 72%,rgba(255,255,255,.4) 0 12%,transparent 13%),radial-gradient(circle at 35% 35%,#9cf6ff 0% 45%,#0050c8 78%,#002c6d);box-shadow:0 0 8px #78d2ffa6,0 4px 10px #03195473;position:relative}.life:after{content:"";position:absolute;inset:3px;border-radius:50%;border:2px solid rgba(255,255,255,.75);border-top-color:transparent;border-bottom-color:transparent;transform:rotate(28deg);opacity:.9}.pacman-board{display:grid;gap:4px;padding:16px;border-radius:20px;background:#050712d9;border:2px solid rgba(91,99,229,.4);box-shadow:0 16px 32px #070b1e80,inset 0 0 0 2px #19205259}.pacman-board-wrapper{display:flex;justify-content:center;align-items:flex-start;margin-bottom:1.5rem}.pacman-board-inner{display:inline-flex;will-change:transform;transition:transform .2s ease}.pacman-board.power-mode{box-shadow:0 18px 36px #070b1e8c,inset 0 0 0 2px #56bdff99,0 0 24px #5ac2ff73;animation:board-pulse .6s ease-in-out alternate infinite}.cell{width:24px;height:24px;border-radius:6px;position:relative;display:flex;align-items:center;justify-content:center}.wall{background:linear-gradient(135deg,#23337af2,#0f1742f2);box-shadow:inset 0 0 6px #0c184ae6}.path{background:#080c20d9}.pellet-dot{width:6px;height:6px;border-radius:50%;background:#ffd15c;box-shadow:0 0 10px #ffd15ccc}.pellet-dot.power{width:14px;height:14px;background:#5ce1ff;box-shadow:0 0 18px #5ce1ffd9}.pacman{--pacman-rotation: 0deg;--pacman-scale: 1.5;width:32px;height:32px;border-radius:50%;position:relative;background-size:cover;background-position:center;background-repeat:no-repeat;overflow:hidden;box-sizing:border-box;box-shadow:0 0 10px #78d2ff73,0 4px 10px #05113766;transition:transform .2s ease;transform:rotate(var(--pacman-rotation)) scale(var(--pacman-scale))}.pacman-left{--pacman-rotation: 180deg}.pacman-right{--pacman-rotation: 0deg}.pacman-up{--pacman-rotation: -90deg}.pacman-down{--pacman-rotation: 90deg}.ghost{width:18px;height:18px;background:var(--ghost-color, #ff5f6d);border-radius:9px 9px 4px 4px;position:relative;box-shadow:0 0 10px #678dff99,inset 0 -4px 6px #05081459}.ghost:before,.ghost:after{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:#f5faff;top:5px}.ghost:before{left:3px}.ghost:after{right:3px}.ghost:after,.ghost:before{box-shadow:inset -1px -1px 2px #12193659}.ghost.frightened{background:linear-gradient(135deg,#8ae0ff,#3a82ff);box-shadow:0 0 14px #62ceffd9,inset 0 -4px 6px #05081466;animation:ghost-frightened .28s ease-in-out alternate infinite}.ghost.frightened:before,.ghost.frightened:after{background:#0b1c3f;box-shadow:none}.pacman-board.power-mode .pellet-dot.power{animation:power-pulse .35s ease-in-out alternate infinite}.pacman-controls{margin-top:1.5rem;text-align:center;color:#dfe3ffe6;max-width:640px;line-height:1.6}.pacman-mobile-controls{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 16px);transform:translate(-50%);width:min(320px,calc(100% - 2rem));padding:1rem 1.25rem 1.15rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;border-radius:22px;background:#050712e0;border:1px solid rgba(91,99,229,.55);box-shadow:0 20px 40px #070b1e8c,0 0 22px #4c67ff40;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:20;transition:transform .3s ease,opacity .3s ease}.pacman-mobile-controls[data-active=false]{opacity:0;pointer-events:none;transform:translate(-50%,calc(100% + 32px))}@media (min-width: 821px){.pacman-mobile-controls{display:none}}@media (max-width: 520px){.pacman-mobile-controls{width:min(300px,calc(100% - 1.5rem));padding:.9rem 1rem 1.05rem}}.pacman-dpad{display:grid;grid-template-areas:". up ." "left center right" ". down .";gap:.65rem;justify-items:center;align-items:center}.pacman-dpad__button{width:52px;height:52px;border-radius:16px;border:2px solid rgba(124,136,255,.45);background:#151837d9;color:#f8f9ff;font-size:1.35rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 24px #0b0d178c;transition:transform .2s ease,box-shadow .2s ease}.pacman-dpad__button:active{transform:translateY(1px) scale(.96);box-shadow:0 10px 18px #0b0d1773}.pacman-dpad__button--up{grid-area:up}.pacman-dpad__button--down{grid-area:down}.pacman-dpad__button--left{grid-area:left}.pacman-dpad__button--right{grid-area:right}.pacman-dpad__center{grid-area:center;width:46px;height:46px;border-radius:14px;background:#6366f138;border:1px solid rgba(99,102,241,.3);box-shadow:inset 0 0 10px #4f46e566}.pacman-mobile-hint{margin-top:.75rem;font-size:.85rem;color:#dfe3ffd9}.status-message{margin-top:1rem;font-size:1rem;font-weight:600;color:#ffd15c;text-shadow:0 0 8px rgba(255,209,92,.4)}.restart-button{margin-top:1rem;background:linear-gradient(135deg,#6f74ff,#9c6fff);border:none;color:#0b0d17;font-weight:700;padding:.65rem 1.5rem;border-radius:999px;cursor:pointer;letter-spacing:.05em;box-shadow:0 12px 20px #4e49b559;transition:transform .2s ease,box-shadow .2s ease}.restart-button:hover{transform:translateY(-1px);box-shadow:0 16px 28px #4e49b573}@media (max-width: 820px){.pacman-hud{font-size:.78rem}.pacman-mobile-controls{display:block}}@media (max-width: 480px){.pacman-dpad__button{width:48px;height:48px;font-size:1.2rem}.pacman-dpad__center{width:42px;height:42px}}@keyframes board-pulse{0%{filter:brightness(1)}to{filter:brightness(1.1)}}@keyframes ghost-frightened{0%{transform:translateY(0) scale(1)}to{transform:translateY(-1px) scale(1.05)}}@keyframes power-pulse{0%{transform:scale(1);box-shadow:0 0 18px #5ce1ffd9}to{transform:scale(1.15);box-shadow:0 0 26px #5ce1fff2}}.space-invaders{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(2rem,4vw,3rem) 1.5rem clamp(7rem,12vw,9rem);background:radial-gradient(circle at 15% 20%,rgba(59,130,246,.16),transparent 55%),radial-gradient(circle at 85% 15%,rgba(236,72,153,.18),transparent 60%),linear-gradient(180deg,#020617,#0b1120 35%,#111827)}.space-invaders__frame{display:flex;flex-direction:column;align-items:center;gap:1.25rem;width:min(560px,100%);position:relative}.space-invaders__canvas{width:100%;height:auto;border-radius:24px;border:2px solid rgba(148,163,184,.35);box-shadow:0 35px 70px #0f172a66;background:#030712}.space-invaders__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:1.5rem;pointer-events:none}.space-invaders__overlay-card{width:min(420px,100%);background:#0f172acc;border:1px solid rgba(148,163,184,.45);border-radius:20px;padding:1.75rem 1.5rem;text-align:center;color:#f1f5f9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 24px 48px #0f172a73;pointer-events:auto}.space-invaders__overlay-card h2{margin:0 0 .75rem;font-size:clamp(1.5rem,4vw,1.9rem)}.space-invaders__overlay-card p{margin:0 0 1.25rem;font-size:.95rem;color:#e2e8f0e6}.space-invaders__launch{background:linear-gradient(135deg,#38bdf8,#6366f1);border:none;color:#0f172a;font-weight:700;padding:.75rem 1.75rem;border-radius:999px;cursor:pointer;box-shadow:0 16px 32px #6366f159;transition:transform .2s ease,box-shadow .2s ease}.space-invaders__launch:hover{transform:translateY(-1px);box-shadow:0 20px 36px #6366f173}.space-invaders__hud{text-align:center;color:#e2e8f0;font-family:Inter,sans-serif;font-size:.95rem;line-height:1.6;padding:1.1rem 1.5rem;border-radius:20px;background:#0f172a8c;border:1px solid rgba(148,163,184,.4);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.space-invaders__hud kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.8rem;padding:.15rem .5rem;border-radius:6px;background:#e2e8f026;border:1px solid rgba(226,232,240,.35);font-size:.8rem;font-weight:600;margin:0 .15rem;color:#f8fafc}.space-invaders__hud strong{color:#c4b5fd}.space-invaders__tip{margin:.35rem 0 0;font-size:.9rem;color:#e2e8f0d9}.space-invaders__controls{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 18px);transform:translate(-50%);width:min(360px,calc(100% - 2.5rem));padding:1rem 1.35rem 1.15rem;display:flex;flex-direction:column;align-items:center;gap:.85rem;border-radius:24px;background:#0f172ae6;border:1px solid rgba(148,163,184,.5);box-shadow:0 24px 48px #02061799,0 0 26px #5eead433;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:22;transition:transform .3s ease,opacity .3s ease}.space-invaders__controls[data-active=false]{opacity:0;pointer-events:none;transform:translate(-50%,calc(100% + 36px))}.space-invaders__controls-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;width:min(360px,100%)}.space-invaders__control-button{height:60px;border-radius:18px;border:2px solid rgba(148,163,184,.4);background:#0f172ad9;color:#e2e8f0;font-size:1.6rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 18px 32px #0f172a73;transition:transform .2s ease,box-shadow .2s ease}.space-invaders__control-button:active{transform:translateY(1px) scale(.97);box-shadow:0 12px 20px #0f172a59}.space-invaders__control-button--shoot{background:linear-gradient(135deg,#38bdf8e6,#818cf8e6);color:#0b1120;border:none}.space-invaders__controls-hint{font-size:.85rem;color:#e2e8f0d9;text-align:center}@media (max-width: 520px){.space-invaders__hud{font-size:.85rem;padding:.9rem 1.2rem}.space-invaders__controls{width:min(320px,calc(100% - 1.5rem));padding:.9rem 1.1rem 1.05rem}.space-invaders__control-button{height:54px;font-size:1.4rem}}@media (min-width: 821px){.space-invaders__controls{display:none}}.snake-game{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,4vw,3rem) clamp(1.25rem,4vw,3rem) clamp(7rem,14vw,10rem);background:radial-gradient(circle at top left,#0b1220,#010409 70%);color:var(--white)}.snake-content{display:grid;grid-template-columns:minmax(240px,320px) minmax(260px,1fr);gap:clamp(1.5rem,3vw,3.5rem);width:min(1040px,100%);align-items:center}.snake-sidebar{display:flex;flex-direction:column;gap:1.25rem;color:var(--white)}.snake-home{font-size:.95rem;font-weight:600;letter-spacing:.02em;color:#ffffffb3;text-decoration:none;transition:color .2s ease}.snake-home:hover{color:var(--white)}.snake-title{font-size:clamp(2.25rem,4vw,3rem);color:var(--white);margin:0}.snake-description{color:#fffc;font-size:1.05rem;margin:0}.snake-instructions{background:#0f172a8c;border:1px solid rgba(59,130,246,.3);border-radius:18px;padding:1.25rem 1.4rem;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.snake-instructions h2{font-size:1.25rem;margin-bottom:.75rem;color:var(--white)}.snake-instructions ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem;font-size:.95rem;color:#fffc}.snake-instructions li:before{content:"✶";margin-right:.65rem;color:var(--accent-soft);display:inline-block}.snake-stats{display:grid;gap:.75rem;background:#1e40af47;border:1px solid rgba(147,197,253,.35);border-radius:18px;padding:1rem 1.25rem;font-family:Inter,sans-serif}.snake-stats .label{display:block;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:#fff9;margin-bottom:.2rem}.snake-stats .value{font-size:1.5rem;font-weight:700;color:var(--white)}.snake-board{position:relative;display:flex;align-items:center;justify-content:center}.snake-canvas{width:min(100%,520px);max-width:520px;aspect-ratio:1 / 1;border-radius:28px;border:3px solid rgba(147,197,253,.5);box-shadow:0 35px 80px #0f172a8c;overflow:hidden;background:#0f172af2}.snake-mobile-controls{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 18px);transform:translate(-50%);width:min(340px,calc(100% - 2.5rem));padding:1rem 1.35rem 1.2rem;display:flex;flex-direction:column;align-items:center;gap:.85rem;border-radius:24px;background:#0f172ae0;border:1px solid rgba(147,197,253,.5);box-shadow:0 22px 44px #02061799,0 0 24px #3b82f640;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:24;transition:transform .3s ease,opacity .3s ease}.snake-mobile-controls[data-active=false]{opacity:0;pointer-events:none;transform:translate(-50%,calc(100% + 36px))}.snake-dpad{display:grid;grid-template-areas:". up ." "left center right" ". down .";gap:.75rem;justify-items:center;align-items:center}.snake-dpad__button{width:56px;height:56px;border-radius:18px;border:2px solid rgba(147,197,253,.4);background:#0f172ad9;color:var(--white);font-size:1.4rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 14px 28px #0f172a73;transition:transform .2s ease,box-shadow .2s ease}.snake-dpad__button:active{transform:translateY(1px) scale(.96);box-shadow:0 10px 18px #0f172a59}.snake-dpad__button--up{grid-area:up}.snake-dpad__button--down{grid-area:down}.snake-dpad__button--left{grid-area:left}.snake-dpad__button--right{grid-area:right}.snake-dpad__center{grid-area:center;width:52px;height:52px;border-radius:16px;background:#2563eb26;border:1px solid rgba(37,99,235,.25);box-shadow:inset 0 0 12px #2563eb4d}.snake-mobile-hint{margin-top:.75rem;font-size:.85rem;color:#e2e8f0d9;text-align:center;max-width:220px}.snake-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#020617bf;border-radius:28px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1.5rem;text-align:center}.overlay-content h2{font-size:1.8rem;color:var(--white);margin-bottom:.75rem}.overlay-content p{color:#ffffffc7;margin-bottom:1.25rem;font-size:1rem}.snake-button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,#60a5fa,#2563eb);color:var(--white);border-radius:999px;padding:.85rem 1.8rem;font-size:1rem;font-weight:600;box-shadow:0 18px 30px #2563eb59;transition:transform .2s ease,box-shadow .2s ease}.snake-button:hover{transform:translateY(-2px);box-shadow:0 20px 36px #2563eb73}.snake-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 12px 24px #2563eb40}.snake-button:disabled:hover{transform:none;box-shadow:0 12px 24px #2563eb40}@media (max-width: 900px){.snake-content{grid-template-columns:1fr}.snake-sidebar{order:2;text-align:center;align-items:center}.snake-instructions ul{text-align:left}.snake-board{order:1}.snake-mobile-controls{width:min(320px,calc(100% - 2rem));padding:.9rem 1.1rem 1.05rem}}@media (max-width: 600px){.snake-game{padding:1.5rem 1rem clamp(7rem,22vw,9.5rem)}.snake-sidebar{gap:1rem}.snake-stats{width:100%;grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 901px){.snake-mobile-controls{display:none}}@media (max-width: 520px){.snake-mobile-controls{width:min(300px,calc(100% - 1.5rem));padding:.85rem 1rem 1rem}}.landing-page{position:relative;min-height:100vh;width:100%;display:flex;flex-direction:column;overflow:hidden;background:radial-gradient(circle at 5% 10%,rgba(59,130,246,.25),transparent 55%),radial-gradient(circle at 90% 10%,rgba(249,115,22,.25),transparent 50%),linear-gradient(180deg,#fff,#f9fafb 60%,#fce7f3)}.landing-background{position:absolute;inset:0;pointer-events:none;background:conic-gradient(from 180deg at 70% 20%,rgba(34,197,94,.12),transparent 55%),conic-gradient(from 45deg at 20% 30%,rgba(37,99,235,.15),transparent 60%);filter:blur(0px);opacity:.9;z-index:0}.main-content{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;gap:3.5rem;padding:clamp(4rem,8vw,6rem) 1.5rem 4rem}.hero{width:min(1100px,100%);background:#ffffffc7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:36px;border:1px solid rgba(15,23,42,.08);padding:clamp(2.75rem,6vw,4.5rem);display:flex;justify-content:center;text-align:center;box-shadow:0 35px 70px #0f172a29}.hero-copy{display:flex;flex-direction:column;gap:1.75rem;align-items:center}.hero-eyebrow{font-family:Inter,sans-serif;font-size:1.05rem;letter-spacing:.28em;text-transform:uppercase;color:#0f172a8c}.hero h1{font-size:clamp(3.5rem,8vw,5.75rem);font-weight:700;line-height:1.05;color:var(--text-primary);text-wrap:balance}.hero-subtitle{font-size:clamp(1.1rem,2.6vw,1.45rem);color:#374151c7;max-width:34rem}.hero-actions{display:flex;justify-content:center}.cta-button{border-radius:999px;padding:.85rem 1.8rem;font-family:Inter,sans-serif;font-weight:700;letter-spacing:.02em;font-size:1.05rem;transition:transform .2s ease,box-shadow .3s ease,background-color .3s ease;border:none;text-decoration:none}.cta-button:hover{transform:translateY(-3px) scale(1.01)}.cta-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--white);box-shadow:0 20px 35px #ef444459}.cta-primary:hover{box-shadow:0 28px 45px #3b82f659}.page-grid{width:min(1100px,100%);display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}.page-card{position:relative;display:flex;flex-direction:column;gap:1.1rem;align-items:flex-start;padding:2.25rem 2rem;border-radius:26px;background:#ffffffd9;border:1px solid rgba(15,23,42,.08);box-shadow:0 25px 45px #0f172a1f;color:inherit;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease}.page-card:hover,.page-card:focus-visible{transform:translateY(-8px);box-shadow:0 35px 65px #0f172a29}.page-card span{font-size:2rem}.page-card h2{margin:0;font-size:1.9rem;color:var(--text-primary)}.page-card p{margin:0;font-family:Inter,sans-serif;font-size:1rem;color:#374151c7}.page-card__meta{margin-top:auto}.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:999px;background:#0f172a14;color:#0f172aad;font-family:Inter,sans-serif;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase}.impact-banner{width:min(1100px,100%);padding:clamp(2.25rem,4.5vw,3rem);border-radius:32px;background:linear-gradient(135deg,#ec4899f2,#3b82f6f2);color:var(--white);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.75rem;box-shadow:0 35px 65px #be185d61}.impact-banner h2{font-size:clamp(2.1rem,4.5vw,3rem);margin:0;color:inherit;text-wrap:balance}.banner-cta{background:var(--white);color:var(--primary);box-shadow:0 25px 40px #0f172a33}.banner-cta:hover{color:var(--accent)}@media (max-width: 1024px){.hero{padding:clamp(2.5rem,5vw,3.5rem)}}.hero{max-width:720px;text-align:center;padding:3rem 2rem;background:#fffc;border-radius:28px;box-shadow:0 30px 60px #bbadff59,inset 0 0 0 1px #fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero h1{font-size:clamp(2.25rem,5vw,3.25rem);margin-bottom:1rem;color:#352b58;font-weight:800;letter-spacing:-.02em}.hero p{font-size:1.1rem;line-height:1.8;color:#5f5575;margin:0 auto 1.5rem;max-width:560px}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.primary-button,.secondary-button{padding:.9rem 1.8rem;border-radius:999px;font-weight:600;text-decoration:none;letter-spacing:.05em;transition:transform .2s ease,box-shadow .2s ease}.primary-button{background:linear-gradient(135deg,#9c6fff,#ff80c8);color:#fff5ff;box-shadow:0 16px 28px #b284ff59}.secondary-button{background:#ffffffb3;color:#584a7d;box-shadow:0 10px 20px #6f67b440;border:1px solid rgba(137,127,196,.4)}.primary-button:hover,.secondary-button:hover{transform:translateY(-2px)}.game-grid{margin-top:3rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;width:min(900px,100%)}.game-card{background:#ffffffbf;border-radius:24px;padding:1.75rem;text-align:left;box-shadow:0 24px 40px #bbadff59;border:1px solid rgba(255,255,255,.65);display:flex;flex-direction:column;gap:1rem}.game-card h2{font-size:1.5rem;color:#43356c;margin:0}.game-card p{margin:0;color:#6e5d8f;line-height:1.6}.card-link{align-self:flex-start;padding:.6rem 1.4rem;border-radius:999px;background:linear-gradient(135deg,#ff85b8,#ffb86c);color:#fff9ff;text-decoration:none;font-weight:600;letter-spacing:.04em;transition:transform .2s ease,box-shadow .2s ease}.card-link:hover{transform:translateY(-2px);box-shadow:0 14px 22px #ff9dbc59}@media (max-width: 768px){.main-content{padding:3.5rem 1.25rem 3rem;gap:2.75rem}.page-card{padding:2rem 1.75rem}.impact-banner{text-align:center;justify-content:center}}@media (max-width: 520px){.hero{border-radius:28px}.cta-button{width:100%;justify-content:center}.page-grid{grid-template-columns:1fr}.page-card{justify-items:center;text-align:center}.hero{padding:2.5rem 1.5rem}}.app-header{display:flex;justify-content:center;padding:1.25rem 2rem 0;position:relative;z-index:2}.nav-links{display:flex;align-items:center;gap:.35rem;padding:.4rem;border-radius:999px;background:linear-gradient(135deg,#ffffffd9,#f3f4f6bf);border:1px solid rgba(148,163,184,.25);box-shadow:0 12px 30px #0f172a14;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.nav-links a{position:relative;padding:.6rem 1.35rem;border-radius:999px;border:none;font-size:.95rem;font-weight:600;letter-spacing:.01em;color:var(--text-secondary);background:transparent;transition:color .3s ease,transform .2s ease}.nav-links a:after{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(120deg,#2563eb1f,#ef44441f);opacity:0;transform:scale(.9);transition:opacity .3s ease,transform .3s ease;z-index:-1}.nav-links a:hover,.nav-links a:focus-visible{color:var(--black);transform:translateY(-1px)}.nav-links a:hover:after,.nav-links a:focus-visible:after{opacity:1;transform:scale(1)}.nav-links a.active{color:var(--black)}.nav-links a.active:after{opacity:1;transform:scale(1);background:linear-gradient(120deg,#2563eb2e,#ef44443d)}.mobile-menu-icon{display:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:.5rem;border-radius:12px;transition:all .3s ease}.mobile-menu-icon:hover{background:#2563eb1f;color:var(--accent)}@media (max-width: 768px){.app-header{padding:1rem 1.25rem}.nav-links{flex-direction:column;gap:.5rem;padding:.75rem;width:calc(100% - 2.5rem);border-radius:24px;position:absolute;top:1rem;left:50%;transform:translate(-50%);background:#fffffff2;border:1px solid rgba(148,163,184,.2);box-shadow:0 20px 40px #0f172a26;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:none}.nav-links.open{display:flex;animation:slideDown .3s ease-out}.nav-links a{width:100%;text-align:center;padding:.85rem 1rem}.nav-links a:hover{transform:none}.mobile-menu-icon{display:block}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.auth-section{display:flex;align-items:center;gap:1rem;margin-left:1rem}.user-greeting{color:var(--text-secondary);font-weight:600;font-size:.9rem}.auth-button{padding:.5rem 1rem;border:none;border-radius:20px;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .3s ease;outline:none;font-family:inherit}.auth-button.login{background:#2563eb1f;color:var(--accent);border:1px solid rgba(37,99,235,.25)}.auth-button.login:hover{background:#2563eb2e;color:var(--accent);border-color:#2563eb59}.auth-button.register{background-color:var(--primary);color:var(--white);border:none}.auth-button.register:hover{background-color:var(--primary-strong);transform:translateY(-1px)}.auth-button.logout{background:#ef44441f;color:var(--primary);border:1px solid rgba(239,68,68,.25)}.auth-button.logout:hover{background:#ef44442e;color:var(--primary)}@media (max-width: 768px){.auth-section{flex-direction:column;align-items:stretch;gap:.5rem;margin-left:0;margin-top:.5rem}.user-greeting{text-align:center;padding:.5rem}.auth-button{padding:.75rem 1rem;text-align:center}}.auth-modal{position:fixed;inset:0;background:#2563eb2e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.auth-modal-content{background-color:var(--surface);border-radius:20px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;position:relative;border:2px solid rgba(37,99,235,.3)}.auth-close-button{position:absolute;top:1rem;right:1rem;background:#2563eb1f;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--accent);font-size:1.2rem;transition:all .3s ease;z-index:1}.auth-close-button:hover{background:#2563eb2e;color:var(--accent);transform:scale(1.1)}.auth-form{padding:2rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h2{color:var(--accent);font-size:1.8rem;margin-bottom:.5rem;font-family:Playfair Display,serif}.auth-header p{color:var(--text-secondary);font-size:.95rem;opacity:.9}.auth-form-content{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--accent);font-weight:500;font-size:.9rem}.form-group input{padding:.875rem 1rem;border:2px solid rgba(37,99,235,.35);border-radius:12px;background:#2563eb14;color:var(--text-primary);font-size:1rem;transition:all .3s ease;outline:none}.form-group input:focus{border-color:var(--accent);background:#2563eb1f}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder{color:#0f172a66;opacity:1}.field-error{color:var(--primary);font-size:.8rem;margin-top:.25rem}.auth-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:.75rem;color:var(--primary);font-size:.9rem;text-align:center}.auth-button{padding:1rem 1.5rem;border:none;border-radius:12px;font-weight:500;font-size:1rem;cursor:pointer;transition:all .3s ease;outline:none;font-family:inherit}.auth-button.primary{background-color:var(--primary);color:#fff}.auth-button.primary:hover:not(:disabled){background-color:var(--primary-strong);transform:translateY(-2px)}.auth-button.primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(37,99,235,.2)}.auth-footer p{color:var(--text-secondary);font-size:.9rem}.auth-link{background:none;border:none;color:var(--accent);cursor:pointer;font-weight:500;text-decoration:underline;text-decoration-color:transparent;transition:all .3s ease;font-size:inherit}.auth-link:hover:not(:disabled){color:var(--accent);text-decoration-color:var(--accent)}.auth-link:disabled{opacity:.6;cursor:not-allowed}.google-signin-button{width:100%;padding:1rem 1.5rem;border:1px solid rgba(37,99,235,.35);border-radius:12px;background:#fff;cursor:pointer;transition:all .3s ease;outline:none;font-family:inherit}.google-signin-button:hover:not(:disabled){border-color:#2563eb73;transform:translateY(-2px)}.google-signin-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.google-signin-content{display:flex;align-items:center;justify-content:center;gap:.75rem}.google-signin-content span{color:#757575;font-weight:500;font-size:1rem}.google-icon,.google-icon-small{flex-shrink:0}.auth-button.google-signin{background:#fff;color:#757575;border:1px solid rgba(37,99,235,.35);display:flex;align-items:center;gap:.5rem}.auth-button.google-signin:hover{background:#ffffffe6;border-color:#2563eb73;transform:translateY(-1px)}@media (max-width: 480px){.auth-modal{padding:.5rem}.auth-form{padding:1.5rem}.auth-header h2{font-size:1.5rem}.google-signin-button{padding:1rem}.auth-button{padding:.875rem 1.25rem}}
