:root{--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "Fira Code", "Consolas", "Monaco", monospace}[data-theme=dark]{--bg-primary: #0a0a0a;--bg-secondary: #141414;--bg-tertiary: #1a1a1a;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--text-muted: #707070;--accent: #3b82f6;--accent-hover: #2563eb;--border: #2a2a2a;--card-bg: #181818;--nav-bg: rgba(10, 10, 10, .95)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--text-primary: #212529;--text-secondary: #495057;--text-muted: #6c757d;--accent: #0066cc;--accent-hover: #0052a3;--border: #dee2e6;--card-bg: #ffffff;--nav-bg: rgba(255, 255, 255, .95)}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background-color .3s ease,color .3s ease}code{font-family:var(--font-mono)}a{color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-hover)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:1rem}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}p{margin-bottom:1rem}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.section{padding:4rem 0}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:.5rem;padding:1.5rem;margin-bottom:1rem;transition:transform .2s ease,box-shadow .2s ease,background-color .3s ease,border-color .3s ease}.card:hover{transform:translateY(-2px);box-shadow:0 10px 30px -10px #00000080}.button{display:inline-block;padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background .2s ease}.button:hover{background:var(--accent-hover)}.text-muted{color:var(--text-secondary)}.grid{display:grid;gap:2rem}.grid-2,.grid-3{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));align-items:stretch}@media (max-width: 768px){h1{font-size:2rem}h2{font-size:1.5rem}.section{padding:2rem 0}}.navigation{position:fixed;top:0;left:0;right:0;background:var(--nav-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:1000;transition:background-color .3s ease,border-color .3s ease}.nav-wrapper{display:flex;justify-content:space-between;align-items:center;padding:1rem 0}.nav-brand{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.nav-brand:hover{color:var(--text-primary)}.nav-content{display:flex;align-items:center;gap:2rem}.nav-links{display:flex;list-style:none;gap:2rem}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:space-around;width:2rem;height:2rem;background:transparent;border:none;cursor:pointer;padding:0;z-index:10}.hamburger{width:2rem;height:.125rem;background:var(--text-primary);border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}.nav-links a{color:var(--text-secondary);font-weight:500;transition:color .2s ease}.nav-links a:hover{color:var(--text-primary)}.theme-toggle-wrapper{position:relative;margin-left:1rem}.theme-toggle{background:transparent;border:1px solid var(--border);border-radius:.375rem;padding:.5rem;font-size:1.25rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem}.theme-toggle:hover{background:var(--bg-secondary);border-color:var(--accent)}.theme-tooltip{position:absolute;top:calc(100% + 10px);right:0;background:var(--text-primary);color:var(--bg-primary);padding:.75rem 2.5rem .75rem 1rem;border-radius:.5rem;font-size:.875rem;white-space:nowrap;box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f;z-index:1002;animation:tooltipFadeIn .3s ease-out}.theme-tooltip:before{content:"";position:absolute;top:-5px;right:10px;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid var(--text-primary)}.tooltip-dismiss{position:absolute;top:50%;right:.5rem;transform:translateY(-50%);background:transparent;border:none;color:var(--bg-primary);font-size:1.25rem;cursor:pointer;padding:.25rem;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:opacity .2s ease}.tooltip-dismiss:hover{opacity:.7}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}.mobile-close{display:none;position:absolute;top:1.5rem;right:1.5rem;background:transparent;border:none;font-size:1.5rem;color:var(--text-primary);opacity:1;cursor:pointer;padding:.5rem;width:2.5rem;height:2.5rem;align-items:center;justify-content:center;border-radius:.375rem;transition:background-color .2s ease;z-index:1002}.mobile-close:hover{background-color:var(--bg-secondary)}.mobile-menu-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000bf;z-index:1000;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .3s ease}@media (max-width: 768px){.desktop-only{display:none!important}}.mobile-menu{display:none;position:fixed;top:0;right:-100%;width:80%;max-width:300px;height:100vh;background:var(--bg-primary);flex-direction:column;justify-content:flex-start;align-items:flex-start;padding:4.5rem 2rem 2rem;transition:right .3s ease-in-out;z-index:10001;box-shadow:-5px 0 20px #00000080;border-left:1px solid var(--border)}.mobile-menu .nav-links a,.mobile-menu .theme-toggle{color:var(--text-primary);opacity:1}.mobile-menu.mobile-open{right:0}@media (max-width: 768px){.mobile-menu,.mobile-menu-toggle,.mobile-close{display:flex}.nav-links{flex-direction:column;width:100%;gap:.75rem}.nav-links li{width:100%}.nav-links a{display:block;font-size:1.125rem;padding:.375rem 0;color:var(--text-primary)!important;opacity:1!important;font-weight:500}.nav-links a:hover{color:var(--accent)!important}.theme-toggle-wrapper{margin-left:0;margin-top:2rem}.mobile-theme-toggle{margin-top:0;margin-bottom:1.5rem}.mobile-menu-overlay{display:block!important}}.hero{padding-top:8rem;padding-bottom:4rem;min-height:60vh;display:flex;align-items:center;position:relative;overflow:hidden;background-image:url(https://images.pexels.com/photos/5473951/pexels-photo-5473951.jpeg);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed}[data-theme=dark] .hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#0a0a0ad9,#0a0a0a99);z-index:0}[data-theme=light] .hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffffe6,#ffffffb3);z-index:0}.hero-content{max-width:800px;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}.hero-profile{margin-bottom:2rem}.hero-profile-img{width:200px;height:200px;border-radius:50%;object-fit:cover;border:4px solid var(--accent);box-shadow:0 20px 40px -10px #0000004d}.hero-text{width:100%}.hero-title{font-size:3rem;font-weight:700;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-title-text{animation:fadeIn .5s ease-in}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.8}.hero-subtitle-text{animation:fadeIn .5s ease-in}.hero-links{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.hero-links a{color:var(--accent);text-decoration:none;font-weight:500;transition:opacity .3s ease}.hero-links a:hover{opacity:.8;text-decoration:underline}.hero-social{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.social-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text-primary);transition:all .2s ease}.social-link:hover{background:var(--bg-tertiary);border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.social-name{font-weight:500}@media (max-width: 768px){.hero{padding-top:6rem}.hero-profile{margin-bottom:1.5rem}.hero-profile-img{width:150px;height:150px}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.1rem}}.projects{background:transparent}.projects.section{padding-top:.5rem;padding-bottom:4rem}.section-title{text-align:center;margin-bottom:2rem}.project-filters{display:flex;justify-content:center;gap:1rem;margin-bottom:1.5rem}.filter-btn{padding:.5rem 1.5rem;background:transparent;border:1px solid var(--border);border-radius:9999px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500}.filter-btn:hover{border-color:var(--accent);color:var(--text-primary)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.project-link{text-decoration:none;color:inherit;display:flex;height:100%}.project-link:hover{color:inherit}.project-card{height:100%;display:flex;flex-direction:column;overflow:hidden;padding:0}.project-image{width:100%;height:200px;overflow:hidden;margin:0 0 1.5rem;flex-shrink:0}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-link:hover .project-image img{transform:scale(1.05)}.project-content{display:flex;flex-direction:column;flex-grow:1;padding:0 1.5rem 1.5rem}.project-title{font-size:1.25rem;margin-bottom:.75rem;color:var(--text-primary)}.project-description{color:var(--text-secondary);flex-grow:1;margin-bottom:1rem}.project-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:auto}.project-tag{padding:.25rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:9999px;font-size:.875rem;color:var(--text-secondary);cursor:default;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.project-filters{flex-wrap:wrap}}[data-theme=dark] .modal-close:hover{background:#ffffff1a;box-shadow:0 0 20px #ff44554d}.tag-header{margin:2rem 0 3rem;border-radius:12px;overflow:hidden;background:var(--background-secondary);box-shadow:0 4px 6px -1px #0000001a;animation:fadeIn .3s ease-out}.tag-header-image{width:100%;height:200px;overflow:hidden;position:relative;background:linear-gradient(135deg,var(--background-secondary) 0%,var(--background-primary) 100%)}.tag-header-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.tag-header:hover .tag-header-image img{transform:scale(1.05)}.tag-header-content{padding:2rem}.tag-header-title{font-size:2rem;margin:0 0 .5rem;color:var(--text-primary)}.tag-header-description{font-size:1.1rem;color:var(--text-secondary);margin:0 0 1rem;line-height:1.6}.tag-header-meta{font-size:.9rem;color:var(--text-tertiary);font-weight:500}@media (max-width: 768px){.tag-header{margin:1.5rem 0 2rem}.tag-header-image{height:150px}.tag-header-content{padding:1.5rem}.tag-header-title{font-size:1.5rem}.tag-header-description{font-size:1rem}}.blog-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.blog-card{display:flex;flex-direction:column;height:100%;padding:0;overflow:hidden}.blog-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}.blog-card-link:hover{color:inherit}.blog-card-link:hover .blog-link{gap:.5rem;color:var(--accent)}.blog-image{width:100%;height:200px;overflow:hidden;flex-shrink:0;position:relative;background-color:var(--background-secondary)}.blog-image:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,transparent 60%,rgba(0,0,0,.1));opacity:0;transition:opacity .3s ease;pointer-events:none}.blog-card:hover .blog-image:after{opacity:1}.blog-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .3s ease}.blog-card:hover .blog-image img{transform:scale(1.08);filter:brightness(1.05)}[data-theme=dark] .blog-image{box-shadow:inset 0 1px #ffffff0d}.blog-content{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1}.blog-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;color:var(--text-muted);font-size:.875rem}.blog-title{font-size:1.5rem;margin-bottom:.75rem;line-height:1.3}.blog-excerpt{color:var(--text-secondary);margin-bottom:1.5rem;flex-grow:1}.blog-link{font-weight:500;display:inline-flex;align-items:center;gap:.25rem;transition:gap .2s ease}.blog-link:hover{gap:.5rem}.blog.section{padding-top:.5rem;padding-bottom:4rem}.tag-cloud-container{margin-bottom:1.5rem}.tag-cloud{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;align-items:center;padding:1rem;background:var(--bg-secondary);border-radius:.75rem;border:1px solid var(--border);transition:all .3s ease;position:relative}.tag-cloud.collapsed{padding:.5rem .75rem;background:transparent;border:none;border-bottom:1px solid var(--border);border-radius:0;margin-bottom:1.5rem;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tag-cloud.collapsed::-webkit-scrollbar{display:none}.tag-cloud.expanded{flex-wrap:wrap;animation:expandIn .3s ease-out}@keyframes expandIn{0%{opacity:.8;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tag-btn{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);border-radius:2rem;font-size:.875rem;cursor:pointer;transition:all .2s ease;font-weight:500;position:relative;white-space:nowrap}.tag-count{font-size:.75em;opacity:.7;margin-left:.25rem;font-weight:400}.tag-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:translateY(-1px)}.tag-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);opacity:1!important}[data-theme=light] .tag-btn.active{background:#0052a3;border-color:#0052a3;box-shadow:0 2px 4px #0000001a}.tag-btn.active .tag-count{opacity:.9}.tag-expand-btn{padding:.5rem 1rem;background:var(--accent);border:1px solid var(--accent);color:#fff;border-radius:2rem;font-size:.875rem;cursor:pointer;transition:all .2s ease;font-weight:600;white-space:nowrap;display:flex;align-items:center;gap:.25rem;box-shadow:0 2px 8px #0000001a}[data-theme=dark] .tag-expand-btn{box-shadow:0 2px 8px #ff445540}.tag-expand-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}[data-theme=dark] .tag-expand-btn:hover{box-shadow:0 4px 12px #ff445559}@keyframes subtlePulse{0%,to{opacity:1}50%{opacity:.9}}.tag-expand-btn{animation:subtlePulse 2s ease-in-out infinite}.tag-expand-btn:hover{animation:none}.tag-expand-btn .arrow{font-size:.75em;transition:transform .2s ease}.tag-label{color:var(--text-secondary);font-size:.875rem;font-weight:500;margin-right:.5rem;white-space:nowrap}.blog-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.75rem;margin-bottom:.75rem;cursor:default!important}.blog-tag{padding:.2rem .6rem;background:var(--tag-color, var(--text-tertiary));border:none;border-radius:3px;font-size:.7rem;color:#fff;font-weight:500;text-transform:uppercase;letter-spacing:.3px;cursor:default!important;-webkit-user-select:none;user-select:none;position:relative;opacity:.7;pointer-events:none;display:inline-block}.blog-tag:after{content:"";position:absolute;bottom:-2px;left:2px;right:2px;height:2px;background:var(--tag-color, var(--text-tertiary));opacity:.2;border-radius:0 0 3px 3px;z-index:-1}@media (max-width: 768px){.blog-grid{grid-template-columns:1fr}.tag-cloud-container{margin-left:-1rem;margin-right:-1rem;margin-bottom:1rem}.tag-cloud{padding:.75rem;gap:.4rem}.tag-cloud.collapsed{padding:.5rem 1rem;justify-content:flex-start;max-width:100vw}.tag-cloud.collapsed .tag-label{flex-shrink:0}.tag-btn{font-size:.8rem!important;padding:.4rem .8rem;flex-shrink:0}.tag-expand-btn{font-size:.8rem;padding:.4rem .8rem;flex-shrink:0;margin-left:auto}.tag-count{display:none}}.view-all{text-align:center;margin-top:3rem}.about{padding-top:6rem;padding-bottom:4rem;min-height:100vh}.about-content{max-width:800px;margin:0 auto}.about-content h1{font-size:2.5rem;margin-bottom:2rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-content h2{font-size:1.75rem;margin-top:2.5rem;margin-bottom:1.5rem;color:var(--text-primary)}.about-content h3{font-size:1.25rem;margin-top:2rem;margin-bottom:1rem;color:var(--text-primary)}.about-content p{font-size:1.125rem;line-height:1.8;color:var(--text-secondary);margin-bottom:1.5rem}.about-content a{color:var(--accent);text-decoration:none;transition:opacity .3s ease}.about-content a:hover{opacity:.8;text-decoration:underline}.about-title{font-size:3rem;margin-bottom:2rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-intro{font-size:1.25rem;line-height:1.8;color:var(--text-primary);margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid var(--border)}.about-section{margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid var(--border)}.about-section:last-child{border-bottom:none}.about-section h2{font-size:2rem;margin-bottom:1.5rem;color:var(--text-primary)}.about-section h3{font-size:1.5rem;margin-top:2rem;margin-bottom:1rem;color:var(--text-primary)}.about-section p{font-size:1.125rem;line-height:1.8;color:var(--text-secondary);margin-bottom:1.5rem}.about-section em{font-style:italic;color:var(--text-primary)}@media (max-width: 768px){.about-content h1{font-size:2rem}.about-content h2{font-size:1.5rem}.about-content h3{font-size:1.15rem}.about-content p{font-size:1rem}.about-title{font-size:2rem}.about-intro{font-size:1.1rem}.about-section h2{font-size:1.5rem}.about-section h3{font-size:1.25rem}.about-section p{font-size:1rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-primary);border-radius:1rem;padding:3rem 2rem;max-width:400px;width:100%;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary);transform:rotate(90deg)}.coming-soon-modal{text-align:center}.coming-soon-icon{font-size:4rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite}.coming-soon-title{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent) 0%,var(--text-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.coming-soon-project-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.coming-soon-message{color:var(--text-secondary);line-height:1.6;margin-bottom:2rem}.coming-soon-emojis{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem}.emoji-bounce{font-size:2rem;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}body:has(.modal-overlay){overflow:hidden}[data-theme=dark] .modal-overlay{background:#000000d9}[data-theme=dark] .modal-content{background:var(--bg-primary);border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff1a,0 0 80px #ff445526}[data-theme=dark] .coming-soon-modal{background:radial-gradient(ellipse at top,rgba(255,68,85,.05),transparent),var(--bg-primary)}[data-theme=dark] .coming-soon-icon{filter:brightness(1.2);text-shadow:0 0 20px rgba(255,68,85,.5)}[data-theme=dark] .emoji-bounce{filter:brightness(1.1)}[data-theme=dark] .coming-soon-title{text-shadow:0 0 30px rgba(255,68,85,.4)}[data-theme=dark] .modal-close:hover{background:#ffffff1a}.now{padding-top:6rem;min-height:100vh}.now-content{max-width:800px;margin:0 auto;line-height:1.8;font-size:1.125rem}.now-content h1{font-size:3rem;margin-bottom:2rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.now-content h2{font-size:2rem;margin-top:3rem;margin-bottom:1rem;color:var(--text-primary)}.now-content h3{font-size:1.5rem;margin-top:2rem;margin-bottom:1rem;color:var(--text-primary)}.now-content p{margin-bottom:1.5rem;color:var(--text-secondary)}.now-content ul,.now-content ol{margin-bottom:1.5rem;padding-left:2rem;color:var(--text-secondary)}.now-content li{margin-bottom:.5rem}.now-content a{color:var(--accent);text-decoration:none;transition:opacity .3s ease}.now-content a:hover{opacity:.8;text-decoration:underline}.now-content blockquote{border-left:4px solid var(--accent);padding-left:1.5rem;margin:2rem 0;font-style:italic;color:var(--text-secondary)}.now-content code{background:var(--surface);padding:.2rem .4rem;border-radius:.25rem;font-family:Consolas,Monaco,monospace;font-size:.9em}.now-content pre{background:var(--surface);padding:1rem;border-radius:.5rem;overflow-x:auto;margin-bottom:1.5rem}.now-content pre code{background:none;padding:0}.now-content img{max-width:100%;height:auto;border-radius:.5rem;margin:2rem 0}.now-content hr{border:none;border-top:1px solid var(--surface);margin:3rem 0}@media (max-width: 768px){.now-content h1{font-size:2rem}.now-content h2{font-size:1.5rem}.now-content h3{font-size:1.25rem}.now-content{font-size:1rem}}.contact{padding-top:6rem;padding-bottom:4rem;min-height:100vh}.contact-title{font-size:3rem;margin-bottom:1rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.contact-intro{font-size:1.25rem;color:var(--text-secondary);margin-bottom:3rem;max-width:600px}.contact-form{max-width:600px}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:inherit;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.375rem;color:var(--text-primary);transition:border-color .2s ease,background-color .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);background:var(--bg-tertiary)}[data-theme=dark] .form-group input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1)}.submit-button{margin-top:1rem}@media (max-width: 768px){.contact-title{font-size:2rem}.contact-intro{font-size:1.1rem}}.not-found{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center}.not-found-content{max-width:600px;margin:0 auto}.rock-animation{margin-bottom:2rem}.floating-emoji{font-size:5rem;display:inline-block;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-20px) rotate(-5deg)}50%{transform:translateY(0) rotate(0)}75%{transform:translateY(-10px) rotate(5deg)}}.not-found-title{font-size:8rem;font-weight:900;line-height:1;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent) 0%,var(--text-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:rockOut 4s ease-in-out infinite}@keyframes rockOut{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.05) rotate(-1deg)}75%{transform:scale(1.05) rotate(1deg)}}.not-found-title .subtitle{display:block;font-size:1.5rem;font-weight:600;margin-top:1rem;background:none;-webkit-text-fill-color:var(--text-primary)}.not-found-message{font-size:1.5rem;color:var(--text-primary);margin-bottom:1rem;font-weight:500}.not-found-submessage{font-size:1.125rem;color:var(--text-secondary);margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}.not-found-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}.not-found-actions .button{padding:.75rem 1.5rem;border-radius:2rem;text-decoration:none;font-weight:600;transition:all .3s ease}.not-found-actions .button.primary{background:var(--accent);color:#fff;border:2px solid var(--accent)}.not-found-actions .button.primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff44554d}.not-found-actions .button.secondary{background:transparent;color:var(--text-primary);border:2px solid var(--border)}.not-found-actions .button.secondary:hover{background:var(--bg-secondary);border-color:var(--accent);color:var(--accent)}.stage-dive{margin-top:3rem;opacity:.8}.dive-text{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;font-style:italic}.ascii-art{font-family:monospace;font-size:.875rem;line-height:1.2;color:var(--text-secondary);background:var(--bg-secondary);padding:1rem;border-radius:.5rem;display:inline-block;text-align:left;animation:stageDive 6s ease-in-out infinite}@keyframes stageDive{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(10px) rotate(2deg)}}@media (max-width: 768px){.not-found-title{font-size:5rem}.not-found-title .subtitle,.not-found-message{font-size:1.25rem}.not-found-submessage{font-size:1rem}.floating-emoji{font-size:4rem}.not-found-actions{flex-direction:column;align-items:center}.not-found-actions .button{width:100%;max-width:250px}}.projects-page{padding-top:6rem;min-height:100vh}@media (max-width: 768px){.page-title{font-size:2rem}.page-subtitle{font-size:1.1rem}}.experiments-page{padding-top:6rem;min-height:100vh}.experiments-page .page-title{font-size:3rem;margin:0;margin-bottom:1rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.experiments-page .page-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:3rem;line-height:1.6}.experiments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto;padding:0 2rem}.experiment-card{display:block;text-decoration:none;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:transform .2s,box-shadow .2s;position:relative}.experiment-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.experiment-thumbnail{width:100%;height:200px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden}.experiment-thumbnail img{width:auto;height:100%;object-fit:contain;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}.experiment-details{padding:1.5rem 1.5rem 3rem}.experiment-details h3{font-size:1.4rem;margin-bottom:.5rem;color:var(--text-primary)}.experiment-details p{font-size:1rem;color:var(--text-secondary);line-height:1.5;margin-bottom:1rem}.experiment-status{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-size:.875rem;font-weight:500;text-transform:uppercase;position:absolute;bottom:1rem;left:1.5rem}.experiment-status.active{background:#4caf501a;color:#4caf50}.experiment-status.beta{background:#ffc1071a;color:#ffc107}.experiment-status.coming-soon{background:#9e9e9e1a;color:#9e9e9e}@media (max-width: 768px){.experiments-page .page-title{font-size:2rem}.experiments-page .page-subtitle{font-size:1.1rem}.experiments-grid{grid-template-columns:1fr;gap:1.5rem;padding:0 1rem}}.guitar-hero-page{padding-top:6rem;padding-bottom:4rem;min-height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a0033,#0a0a0a);position:relative;overflow:hidden}.guitar-hero-page:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(147,51,234,.03) 2px,rgba(147,51,234,.03) 4px),repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(59,130,246,.03) 2px,rgba(59,130,246,.03) 4px);pointer-events:none;z-index:1}.guitar-hero-container{max-width:900px;margin:0 auto;padding:2rem 0;text-align:center;position:relative;z-index:2}.guitar-hero-page .back-link{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:2rem;color:#0ff;text-decoration:none;transition:all .3s ease;font-family:Courier New,monospace;font-weight:700;text-transform:uppercase;letter-spacing:1px}.guitar-hero-page .back-link:hover{color:#f0f;text-shadow:0 0 10px #ff00ff,0 0 20px #ff00ff}.game-header{margin-bottom:2rem;position:relative}.game-header h1{font-size:3.5rem;margin-bottom:.5rem;font-family:Impact,Arial Black,sans-serif;text-transform:uppercase;letter-spacing:3px;color:#f0f;text-shadow:0 0 10px #ff00ff,0 0 20px #ff00ff,0 0 30px #ff00ff,0 0 40px #00ffff,0 0 50px #00ffff,0 0 60px #00ffff,0 0 70px #00ffff;animation:neon-pulse 1.5s ease-in-out infinite alternate}@keyframes neon-pulse{0%{text-shadow:0 0 10px #ff00ff,0 0 20px #ff00ff,0 0 30px #ff00ff,0 0 40px #00ffff,0 0 50px #00ffff,0 0 60px #00ffff,0 0 70px #00ffff}to{text-shadow:0 0 5px #ff00ff,0 0 10px #ff00ff,0 0 15px #ff00ff,0 0 20px #00ffff,0 0 25px #00ffff,0 0 30px #00ffff,0 0 35px #00ffff}}.game-header p{font-size:1.4rem;color:#ff0;font-family:Courier New,monospace;font-weight:700;text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 5px #ffff00}.game-canvas{border:4px solid #00ffff;border-radius:12px;box-shadow:0 0 20px #0ff,0 0 40px #0ff,inset 0 0 20px #00ffff1a;max-width:100%;height:auto;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;position:relative;background:#000}.game-controls{margin-top:2rem}.control-info{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.control-item{display:flex;align-items:center;gap:.5rem}.control-item .key{display:inline-block;padding:.7rem 1.2rem;background:#1a0033;border:3px solid #ff00ff;border-radius:8px;font-family:Courier New,monospace;font-weight:700;font-size:1.1rem;color:#0ff;box-shadow:0 0 10px #f0f,inset 0 0 10px #f0f3;text-transform:uppercase;letter-spacing:1px}.control-item span:last-child{color:#ff0;font-size:1.1rem;font-family:Courier New,monospace;font-weight:700;text-transform:uppercase;text-shadow:0 0 5px #ffff00}.touch-controls{display:flex;justify-content:center;gap:1rem;margin:2rem 0;padding:1.5rem;background:#1a0033cc;border-radius:20px;border:3px solid #ff00ff;box-shadow:0 0 20px #f0f,inset 0 0 20px #ff00ff1a}.touch-button{width:80px;height:80px;font-size:1.5rem;font-weight:700;font-family:Arial Black,sans-serif;background:#1a0033;border:4px solid #00ffff;border-radius:50%;color:#0ff;cursor:pointer;transition:all .1s ease;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:0 0 15px #0ff,inset 0 0 15px #0ff3;text-shadow:0 0 10px #00ffff}.touch-button:active{transform:scale(.95);background:#0ff;border-color:#0ff;color:#1a0033;box-shadow:0 0 30px #0ff,inset 0 0 10px #0000004d}.touch-shoot{width:100px;height:100px;font-size:1.2rem;background:#f0f;border-color:#f0f;color:#fff;box-shadow:0 0 20px #f0f,inset 0 0 15px #fff3;animation:shoot-pulse .8s ease-in-out infinite alternate}@keyframes shoot-pulse{0%{box-shadow:0 0 20px #f0f,inset 0 0 15px #fff3}to{box-shadow:0 0 30px #f0f,inset 0 0 20px #ffffff4d}}.touch-shoot:active{background:#f6f;transform:scale(.95);animation:none}.restart-button{margin-top:1rem;padding:1rem 2rem;font-size:1.2rem;font-weight:700;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s ease}.restart-button:hover{background:var(--accent-hover)}.restart-button:focus{outline:3px solid var(--accent);outline-offset:2px}.restart-button:focus:not(:focus-visible){outline:none}.restart-button.mobile-top{margin-top:.5rem;margin-bottom:0;width:100%;max-width:200px;margin-left:auto;margin-right:auto;display:block}@media (max-width: 768px){.guitar-hero-page{padding-top:5rem;padding-bottom:2rem}.guitar-hero-container{padding:1rem}.game-header h1{font-size:2.5rem}.game-header p{font-size:1.1rem}.game-canvas{width:100%;height:auto;max-width:600px}.control-info{gap:1rem}.control-item .key{padding:.5rem .9rem;font-size:.9rem}.touch-controls{margin-top:1rem}}.media-player-page *{box-sizing:border-box}.media-player-page{padding-top:7rem;padding-bottom:4rem;min-height:100vh;width:100%;overflow-x:hidden;box-sizing:border-box}.media-player-page>.media-player-container{max-width:1200px;margin:0 auto;padding:0 1rem;width:100%;box-sizing:border-box}.media-player-container{max-width:100%;margin:0;padding:2rem 0;width:100%;box-sizing:border-box}.back-link{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.media-header{margin-bottom:2rem;text-align:center}.media-header h1{font-size:2.5rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.player-header{padding:1rem 0;margin-bottom:1rem;width:100%;box-sizing:border-box}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid var(--color-border, #333);border-radius:8px;color:var(--color-text-secondary, #999);font-size:.875rem;cursor:pointer;transition:all .2s}.back-button:hover{background:var(--color-surface, #1a1a1a);color:var(--color-text-primary, #fff);border-color:var(--color-text-secondary, #666)}.light-mode .back-button{border-color:#e5e7eb;color:#6b7280}.light-mode .back-button:hover{background:#f3f4f6;color:#111827;border-color:#d1d5db}.media-header p{font-size:1.2rem;color:var(--text-secondary)}.loading,.error{text-align:center;padding:4rem 2rem;font-size:1.2rem}.error{color:#ff6b6b}.media-player-wrapper{width:100%;max-width:100%;box-sizing:border-box}.player-layout{display:flex;flex-direction:column;max-width:900px;margin:0 auto;width:100%;text-align:left}.player-layout.layout-simple{max-width:900px}.player-layout.layout-simple .player-section{max-width:none;margin:0}.player-layout.layout-sidebar,.player-layout.layout-sidebar-multi{max-width:100%;width:100%}.player-layout.layout-sidebar.with-playlist,.player-layout.layout-sidebar-multi.with-playlist{display:grid;grid-template-columns:2fr minmax(350px,1fr);gap:2rem;align-items:start}.player-layout.layout-tutorial{display:flex;flex-direction:column;max-width:100%!important;width:100%;margin:0 auto}.player-layout.layout-tutorial .player-section{max-width:100%!important;margin:0;background:transparent;box-shadow:none;padding:0}.player-layout.layout-tutorial .media-container{border-radius:12px;overflow:hidden;box-shadow:0 8px 16px #0003}.player-layout.layout-tutorial .media-info{padding:1.5rem 1rem .5rem}.player-layout.layout-tutorial .controls{padding:0 1rem 1rem}.player-layout.layout-tutorial .playlist-section{background:#ffffff0d;box-shadow:none;max-height:none;margin-top:2rem;padding:1.5rem;width:100%;max-width:100%;border-radius:12px}.player-layout.layout-tutorial .playlist-section h3{margin-bottom:1rem;font-size:1.25rem}.player-layout.layout-tutorial .playlist-items{display:flex;gap:1rem;overflow-x:auto;padding-bottom:1rem;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}.player-layout.layout-tutorial .playlist-items::-webkit-scrollbar{height:6px}.player-layout.layout-tutorial .playlist-items::-webkit-scrollbar-track{background:transparent}.player-layout.layout-tutorial .playlist-items::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.player-layout.layout-tutorial .playlist-items::-webkit-scrollbar-thumb:hover{background:#ffffff80}.player-layout.layout-tutorial .playlist-item{flex-shrink:0;width:200px;margin-bottom:0;background:#ffffff0d}.player-layout.layout-tutorial .playlist-item-thumbnail{width:100%;height:112px}.player-layout.layout-tutorial .playlist-item-info{padding:.75rem}.player-layout.layout-tutorial .playlist-item-title{font-size:.875rem}.player-layout.layout-tutorial .playlist-item-artist{font-size:.75rem}.player-section{background:#ffffff0d;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;overflow:hidden;width:100%;max-width:900px;margin:0 auto}.player-layout.layout-sidebar.with-playlist .player-section{max-width:none;margin:0}.media-container{width:100%;aspect-ratio:16 / 9;background:#000;border-radius:0;overflow:hidden;position:relative;margin-bottom:1rem}.media-element{width:100%;height:100%;object-fit:cover;max-width:100%}.audio-visualization{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#000}.audio-visualization img{width:100%;height:100%;object-fit:cover;border-radius:0}.audio-placeholder{opacity:.8;color:#fff}.audio-placeholder svg{width:80px;height:80px}.media-info{margin-bottom:1.5rem}.media-info h2{font-size:1.5rem;margin:0}.media-info-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.media-info p{color:#ffffffb3;font-size:1.1rem}.view-count{display:flex;align-items:center;gap:6px;color:var(--color-text-secondary, #999);font-size:14px;white-space:nowrap}.view-count svg{opacity:.7}.light-mode .view-count{color:#6b7280}.controls{display:flex;flex-direction:column;gap:0}.control-button{background:transparent;border:none;border-radius:4px;width:36px;height:36px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;color:inherit}.control-button svg{width:20px;height:20px}.control-button:hover:not(:disabled){background:#ffffff1a}.control-button:disabled{opacity:.5;cursor:not-allowed}.control-button.play-pause{width:40px;height:40px}.control-button.play-pause svg{width:24px;height:24px}.progress-wrapper{position:relative;padding:0 12px;margin-bottom:8px}.progress-container{width:100%}.loading-bar-container{width:100%;display:flex;flex-direction:column;gap:.5rem}.loading-bar{width:100%;height:4px;background:#fff3;border-radius:2px;overflow:hidden;position:relative}.loading-bar-fill{height:100%;background:var(--primary-color, #646cff);border-radius:2px;transition:width .3s ease;position:relative}.loading-bar-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.loading-text{font-size:.75rem;color:#ffffffb3;text-align:center}.controls-bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 12px;height:48px}.controls-left{display:flex;align-items:center;justify-content:flex-start}.controls-center{display:flex;align-items:center;gap:8px}.controls-right{display:flex;align-items:center;justify-content:flex-end}.time-display{position:absolute;right:12px;top:-20px;display:flex;align-items:center;font-size:.9rem;color:#ffffffb3}.time{font-size:.9rem;color:#ffffffb3}.time-separator{color:#ffffff80}.progress-bar{width:100%;height:12px;background:transparent;border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none;position:relative}.progress-bar::-webkit-slider-runnable-track{width:100%;height:4px;background:#fff3;border-radius:2px}.progress-bar::-moz-range-track{width:100%;height:4px;background:#fff3;border-radius:2px}.progress-bar::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:var(--primary-color, #646cff);border-radius:50%;cursor:pointer;transition:transform .2s;margin-top:-4px}.progress-bar:hover::-webkit-slider-thumb{transform:scale(1.3)}.progress-bar::-moz-range-thumb{width:12px;height:12px;background:var(--primary-color, #646cff);border-radius:50%;cursor:pointer;border:none;transition:transform .2s}.progress-bar:hover::-moz-range-thumb{transform:scale(1.3)}.volume-container{display:flex;align-items:center;gap:4px}.volume-hint{color:#ffffffb3;font-size:.75rem;margin-left:8px;white-space:nowrap}.volume-button{background:transparent;border:none;width:40px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s;color:inherit}.volume-button svg{width:20px;height:20px}.volume-button:hover{background:#ffffff1a}.volume-slider{width:0;overflow:hidden;transition:width .2s;height:12px;background:transparent;border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none}.volume-container:hover .volume-slider{width:80px}.volume-slider::-webkit-slider-runnable-track{width:100%;height:4px;background:#fff3;border-radius:2px}.volume-slider::-moz-range-track{width:100%;height:4px;background:#fff3;border-radius:2px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:var(--primary-color, #646cff);border-radius:50%;cursor:pointer;margin-top:-4px}.volume-slider::-moz-range-thumb{width:12px;height:12px;background:var(--primary-color, #646cff);border-radius:50%;cursor:pointer;border:none}.playlist-section{background:#ffffff0d;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;max-height:calc(100vh - 4rem);display:flex;flex-direction:column;width:100%;min-width:350px;box-sizing:border-box}.playlist-section h3{font-size:1.3rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.playlist-selector-dropdown{margin-bottom:1rem;position:relative;z-index:10}.playlist-dropdown-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;opacity:.7;margin-bottom:.5rem}.playlist-dropdown-hint{font-size:.75rem;opacity:.6;margin-top:.5rem;font-style:italic}.playlist-dropdown{width:100%;padding:.75rem 2.5rem .75rem 1rem;background:#ffffff14;border:2px solid rgba(255,255,255,.3);border-radius:8px;color:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.8)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem center;background-size:1.2em}.playlist-dropdown:hover{background-color:#ffffff14;border-color:#ffffff4d}.playlist-dropdown:focus{border-color:var(--primary-color, #646cff);box-shadow:0 0 0 2px #646cff33}@media (max-width: 768px){.playlist-dropdown{background:#1a1a1a;color:#fff;border:1px solid #333}.light-mode .playlist-dropdown{background:#fff;color:#111827;border:1px solid #e5e7eb}.playlist-dropdown option{background:inherit;color:inherit}}.light-mode .playlist-dropdown{background-color:#f3f4f6;border-color:#9ca3af;color:#111827;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(0,0,0,0.7)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem center;background-size:1.2em}.light-mode .playlist-dropdown-label{color:#6b7280}.light-mode .playlist-dropdown-hint{color:#9ca3af}.light-mode .playlist-dropdown:hover{background:#f9fafb;border-color:#d1d5db}.light-mode .playlist-dropdown option{background:#fff;color:#111827}.playlist-items{flex:1;overflow-y:auto;padding-right:.5rem}.playlist-items::-webkit-scrollbar{width:8px}.playlist-items::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.playlist-items::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.playlist-items::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.playlist-item{display:flex;gap:1rem;padding:.75rem;margin-bottom:.5rem;border-radius:8px;cursor:pointer;transition:background .2s;position:relative}.playlist-item:hover{background:#ffffff1a}.playlist-item.active{background:#646cff33;border:1px solid rgba(100,108,255,.4)}.playlist-item-thumbnail{width:80px;height:60px;flex-shrink:0;background:#ffffff0d;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center}.playlist-item-thumbnail img{width:100%;height:100%;object-fit:cover}.thumbnail-placeholder{opacity:.7;color:inherit}.thumbnail-placeholder svg{width:24px;height:24px}.playlist-item-info{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0}.playlist-item-title{font-weight:500;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-item-meta{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#ffffff80;margin-top:2px}.playlist-item-artist{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-item-dot{opacity:.5}.playlist-item-details{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.playlist-item-views{display:flex;align-items:center;gap:4px}.playlist-item-views svg{opacity:.6}.playlist-item-duration{font-size:.85rem;color:#ffffff80}.playlist-item-resume{font-size:.8rem;color:var(--primary-color, #646cff);background:#646cff1a;padding:2px 6px;border-radius:4px;font-weight:500}.share-button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;color:inherit;opacity:.7}.playlist-item:hover .share-button{opacity:1}.share-button:hover{background:#fff3;transform:translateY(-50%) scale(1.05)}.share-button .copied-text{font-size:.75rem;font-weight:500;color:#4caf50;white-space:nowrap}@media (max-width: 1024px){.player-layout.layout-sidebar.with-playlist,.player-layout.layout-sidebar-multi.with-playlist{grid-template-columns:1fr;display:flex;flex-direction:column}.playlist-section{max-height:400px;order:2;max-width:100%}.player-section,.player-layout.layout-tutorial{max-width:100%}.player-layout.layout-tutorial .playlist-horizontal .playlist-items{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media (max-width: 926px) and (orientation: landscape){.media-player-container{padding:.5rem 0}.player-layout.layout-sidebar.with-playlist,.player-layout.layout-sidebar-multi.with-playlist{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;padding:0;margin:0;width:100%}.playlist-section{order:0;max-height:calc(100vh - 80px);margin:0;padding:.5rem}.media-container{max-height:calc(100vh - 120px)}.player-layout{padding:0;margin:0;width:100%}.player-section{padding:.5rem;margin:0}.playlist-section,.player-layout.layout-tutorial{padding:.5rem}.player-layout.layout-tutorial .playlist-section{margin-top:.5rem;padding:.75rem}.player-layout.layout-tutorial .playlist-items{flex-direction:row;overflow-x:auto;overflow-y:hidden;max-height:none}.player-layout.layout-tutorial .playlist-item{width:200px;flex-shrink:0}.player-layout.layout-tutorial .playlist-item-thumbnail{width:100%;height:112px}}@media (max-width: 768px){.media-player-page{padding:5rem 0 2rem;box-sizing:border-box}.media-player-page>.media-player-container{padding:0 1rem;width:100%;max-width:100%;box-sizing:border-box}.player-layout{width:100%;max-width:100%;gap:.5rem;margin:0;padding:.5rem}.media-player-container h1{font-size:2rem}.player-section,.playlist-section{padding:.5rem;width:100%;box-sizing:border-box;border-radius:0;margin:0}.media-container{aspect-ratio:16 / 9;max-height:30vh;width:100%;max-width:100%;margin:0;border-radius:0}.media-info{margin-top:1rem;margin-bottom:1rem}.media-info h2{font-size:1.2rem}.media-info-header{flex-direction:column;gap:.5rem}.media-info p{font-size:1rem}.control-button{width:32px;height:32px}.control-button svg{width:18px;height:18px}.control-button.play-pause{width:36px;height:36px}.control-button.play-pause svg{width:20px;height:20px}.controls-bar{height:40px;grid-template-columns:auto 1fr auto}.controls-center{margin:0 auto}.playlist-item{padding:.5rem 2.5rem .5rem .5rem;position:relative}.playlist-item-thumbnail{width:80px;height:60px}.playlist-item-thumbnail img{width:100%;height:100%;object-fit:cover}.volume-container{position:relative;display:flex;align-items:center}.volume-hint{font-size:.65rem;margin-left:4px}.volume-container .volume-slider{display:none}.volume-hint{display:inline-block}.volume-slider::-webkit-slider-thumb{width:20px;height:20px}.volume-slider::-moz-range-thumb{width:20px;height:20px}.time-display{font-size:.75rem;top:-16px;right:8px}.progress-wrapper{padding:0 8px;margin-bottom:4px}.share-button{opacity:1;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);padding:.35rem;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center}.share-button svg{width:14px;height:14px}.share-button .copied-text{font-size:.6rem;white-space:nowrap}.playlist-item-info{min-width:0;flex:1;padding-right:.5rem}.playlist-item-title,.playlist-item-artist{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-item-details{display:inline-flex;align-items:center;gap:.3rem;margin-top:.2rem}.playlist-item-duration{font-size:.75rem}.playlist-item-resume{font-size:.7rem;padding:1px 4px}.playlist-section{max-height:50vh;margin-top:1rem}.playlist-section h3{font-size:1.1rem;margin-bottom:.75rem;padding-bottom:.5rem}.playlist-items{max-height:calc(50vh - 4rem);overflow-y:auto;-webkit-overflow-scrolling:touch}.playlist-selector-dropdown{margin-bottom:.75rem}.playlist-dropdown{padding:.6rem 2.5rem .6rem .9rem;font-size:.9rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.8)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem center;background-size:1em}.player-layout.layout-tutorial{flex-direction:column;padding:0}.player-layout.layout-tutorial .player-section{margin-bottom:.5rem;border-radius:0;padding:0;background:transparent}.player-layout.layout-tutorial .media-container{border-radius:0}.player-layout.layout-tutorial .playlist-section.playlist-horizontal{padding:.75rem;margin:0;background:#ffffff0d;border-radius:0}.player-layout.layout-tutorial .playlist-section.playlist-horizontal h3{font-size:1.1rem;margin-bottom:.75rem}.player-layout.layout-tutorial .playlist-section.playlist-horizontal .playlist-items{display:flex;flex-direction:column;gap:.5rem;max-height:calc(100vh - 400px);min-height:300px;overflow-y:auto;overflow-x:hidden;padding:0}.player-layout.layout-tutorial .playlist-item{width:100%;margin:0;display:flex;gap:.75rem;padding:.5rem;background:#ffffff0d}.player-layout.layout-tutorial .playlist-item-thumbnail{width:120px;height:90px;flex-shrink:0}.player-layout.layout-tutorial .playlist-item-thumbnail img{width:100%;height:100%;object-fit:cover}.player-layout.layout-tutorial .playlist-item-info{flex:1;min-width:0;padding:0}.light-mode .player-layout.layout-tutorial .player-section,.light-mode .player-layout.layout-tutorial .playlist-section.playlist-horizontal{background:#0000000d}.player-layout.layout-simple{padding:.75rem}.player-layout.layout-simple .player-section{padding:0}.media-player-wrapper{width:100%;max-width:100%;overflow-x:hidden}}@media (max-width: 400px){.media-player-page{padding:4.5rem 0 2rem}.player-section{border-radius:6px;padding:.5rem}.media-container{max-height:25vh}.media-info h2{font-size:1.1rem}.media-info p{font-size:.9rem}.player-header{padding:.75rem .5rem;margin-bottom:.5rem}.back-button{padding:.4rem .8rem;font-size:.85rem}.back-button svg{width:18px;height:18px}}input[type=range].progress-bar,input[type=range].volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer}input[type=range].progress-bar::-webkit-slider-track,input[type=range].volume-slider::-webkit-slider-track{background:#333;height:4px;border-radius:2px}input[type=range].progress-bar::-moz-range-track,input[type=range].volume-slider::-moz-range-track{background:#333;height:4px;border-radius:2px}input[type=range].progress-bar::-webkit-slider-thumb,input[type=range].volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#646cff;height:16px;width:16px;border-radius:50%;margin-top:-6px}input[type=range].progress-bar::-moz-range-thumb,input[type=range].volume-slider::-moz-range-thumb{background:#646cff;height:16px;width:16px;border-radius:50%;border:none}.light-mode input[type=range].progress-bar::-webkit-slider-track,.light-mode input[type=range].volume-slider::-webkit-slider-track{background:#ccc!important;border:1px solid #999!important}.light-mode input[type=range].progress-bar::-moz-range-track,.light-mode input[type=range].volume-slider::-moz-range-track{background:#ccc!important;border:1px solid #999!important}@media (prefers-color-scheme: dark){.player-section,.playlist-section{background:#ffffff0d}}[data-theme=light] .media-player-page{color:#213547}[data-theme=light] .player-section,[data-theme=light] .playlist-section{background:#0000000d;box-shadow:0 4px 6px #0000000d}[data-theme=light] .back-link{color:#646cff}[data-theme=light] .media-info h2{color:#213547}[data-theme=light] .media-info p{color:#000000b3}[data-theme=light] .control-button{background:transparent;color:#213547}[data-theme=light] .control-button:hover:not(:disabled){background:#0000001a}[data-theme=light] .volume-button{background:transparent;color:#213547}[data-theme=light] .volume-button:hover{background:#0000001a}[data-theme=light] .volume-hint{color:#0009}[data-theme=light] .time,[data-theme=light] .time-display{color:#000000b3}[data-theme=light] .time-separator{color:#00000080}[data-theme=light] .progress-bar,[data-theme=light] .volume-slider{background:#d0d0d0;height:6px;border:1px solid #999;border-radius:3px}[data-theme=light] .progress-bar::-webkit-slider-track,[data-theme=light] .volume-slider::-webkit-slider-track{background:#d0d0d0!important;height:6px!important;border:1px solid #999!important;border-radius:3px!important}[data-theme=light] .progress-bar::-moz-range-track,[data-theme=light] .volume-slider::-moz-range-track{background:#d0d0d0!important;height:6px!important;border:1px solid #999!important;border-radius:3px!important}[data-theme=light] .progress-bar::-webkit-slider-thumb{background:#4040ff!important;box-shadow:0 0 0 1px #fff,0 0 0 2px #333!important;border:none!important}[data-theme=light] .progress-bar::-moz-range-thumb{background:#4040ff!important;box-shadow:0 0 0 1px #fff,0 0 0 2px #333!important;border:none!important}[data-theme=light] .volume-slider::-webkit-slider-thumb{background:#4040ff!important;box-shadow:0 0 0 1px #fff,0 0 0 2px #333!important;border:none!important}[data-theme=light] .volume-slider::-moz-range-thumb{background:#4040ff!important;box-shadow:0 0 0 1px #fff,0 0 0 2px #333!important;border:none!important}[data-theme=light] .playlist-section h3{color:#213547}[data-theme=light] .player-layout.layout-tutorial .playlist-section{background:#0000000d}[data-theme=light] .playlist-item{color:#213547}[data-theme=light] .playlist-item:hover{background:#0000001a}[data-theme=light] .playlist-item.active{background:#646cff1a}[data-theme=light] .playlist-item-title{color:#213547}[data-theme=light] .playlist-item-artist{color:#0009}[data-theme=light] .playlist-item-duration{color:#00000080}[data-theme=light] .playlist-item-resume{background:#646cff1a;color:#646cff}[data-theme=light] .playlist-items::-webkit-scrollbar-track{background:#0000000d}[data-theme=light] .playlist-items::-webkit-scrollbar-thumb{background:#0003}[data-theme=light] .playlist-items::-webkit-scrollbar-thumb:hover{background:#0000004d}[data-theme=light] .loading-bar{background:#0000001a}[data-theme=light] .loading-text{color:#000000b3}[data-theme=light] .share-button{background:#0000000d;border:1px solid rgba(0,0,0,.1);color:#213547}[data-theme=light] .share-button:hover{background:#0000001a}.playlist-selector{padding:20px;max-width:1200px;margin:0 auto}.playlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.playlist-card{background:var(--color-surface, #1a1a1a);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;border:1px solid var(--color-border, #333)}.playlist-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.playlist-card.completed{border-color:var(--color-success, #10b981)}.playlist-card-thumbnail{position:relative;width:100%;height:180px;background:var(--color-surface-alt, #252525);overflow:hidden}.playlist-card-thumbnail img{width:100%;height:100%;object-fit:cover}.playlist-card-thumbnail.no-image .playlist-overlay{opacity:1}.playlist-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.playlist-card:hover .playlist-overlay{opacity:1}.playlist-overlay svg{color:var(--color-primary, #fff)}.completion-badge{position:absolute;top:12px;right:12px;background:var(--color-success, #10b981);color:#fff;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d}.playlist-card-content{padding:20px}.playlist-card-content h3{margin:0 0 8px;font-size:1.25rem;color:var(--color-text-primary, #fff)}.playlist-description{color:var(--color-text-secondary, #999);font-size:.875rem;margin:0 0 16px;line-height:1.5}.playlist-stats{display:flex;gap:16px;margin-bottom:16px;font-size:.875rem;color:var(--color-text-secondary, #999)}.playlist-duration{display:flex;align-items:center;gap:4px}.playlist-progress{margin-bottom:16px}.progress-bar-background{height:6px;background:var(--color-surface-alt, #333);border-radius:3px;overflow:hidden;margin-bottom:8px}.progress-bar-fill{height:100%;background:var(--color-primary, #3b82f6);border-radius:3px;transition:width .3s ease}.playlist-card.completed .progress-bar-fill{background:var(--color-success, #10b981)}.progress-text{font-size:.75rem;color:var(--color-text-secondary, #999)}.playlist-play-button{width:100%;padding:12px 20px;background:var(--color-primary, #3b82f6);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color .2s}.playlist-play-button:hover{background:var(--color-primary-hover, #2563eb)}.playlist-card.completed .playlist-play-button{background:var(--color-success, #10b981)}.playlist-card.completed .playlist-play-button:hover{background:var(--color-success-hover, #059669)}.light-mode .playlist-card{background:#fff;border-color:#e5e7eb}.light-mode .playlist-card-thumbnail{background:#f3f4f6}.light-mode .playlist-card-content h3{color:#111827}.light-mode .playlist-description,.light-mode .playlist-stats,.light-mode .progress-text{color:#6b7280}.light-mode .progress-bar-background{background:#e5e7eb}@media (max-width: 768px){.playlist-selector{padding:16px}.playlist-grid{grid-template-columns:1fr;gap:16px}.playlist-card-thumbnail{height:140px}}.stoic-landing-page{position:fixed;top:0;left:0;width:100vw;height:100vh;overflow:hidden;z-index:9999}.stoic-footer{position:fixed;bottom:60px;left:0;right:0;display:flex;justify-content:center;align-items:center;padding:1rem 2rem;background:transparent;pointer-events:none;z-index:10}.stoic-footer>*{pointer-events:auto}.stoic-info{font-size:.85rem;text-align:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#fff9;text-shadow:0 1px 2px rgba(0,0,0,.3)}.light-theme .stoic-info{color:#0009;text-shadow:0 1px 2px rgba(255,255,255,.5)}@media (max-width: 768px){.stoic-footer{padding:.75rem 1rem}.stoic-info{font-size:.75rem;max-width:200px}}.blog-page{padding-top:6rem;min-height:100vh}.blog-page .blog-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.blog-page .page-title{font-size:3rem;margin:0;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.blog-page .rss-link{color:var(--text-secondary);transition:color .3s ease;display:flex;align-items:center;justify-content:center;padding:.5rem}.blog-page .rss-link:hover{color:var(--accent)}.blog-page .page-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:1rem}@media (max-width: 768px){.blog-page .page-title{font-size:2rem}.blog-page .page-subtitle{font-size:1.1rem}.blog-page .rss-link{padding:.25rem}.blog-page .rss-link svg{width:20px;height:20px}}.carousel-container{width:100%;max-width:900px;margin:2rem auto;-webkit-user-select:none;user-select:none}.carousel-main{position:relative;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:8px;overflow:hidden}.carousel-image-wrapper{width:100%;display:flex;justify-content:center;align-items:center;min-height:400px;background:transparent}.carousel-image{width:100%;height:auto;max-height:600px;object-fit:contain;display:block}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#0009;color:#fff;border:none;font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .3s ease;z-index:10;border-radius:50%;line-height:1;padding:0;font-family:Arial,sans-serif}.carousel-arrow:hover{background:#000c}.carousel-arrow:active{background:#000000e6}.carousel-arrow-left{left:1rem}.carousel-arrow-right{right:1rem}.carousel-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem;padding:.5rem}.carousel-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--text-primary, #333);background:transparent;cursor:pointer;transition:all .3s ease;padding:0}.carousel-dot:hover{background:var(--text-secondary, #666)}.carousel-dot.active{background:var(--text-primary, #333);transform:scale(1.2)}[data-theme=dark] .carousel-main,[data-theme=dark] .carousel-image-wrapper{background:transparent}[data-theme=dark] .carousel-dot{border-color:var(--text-primary, #e0e0e0)}[data-theme=dark] .carousel-dot.active{background:var(--text-primary, #e0e0e0)}@media (max-width: 768px){.carousel-arrow{width:40px;height:40px;font-size:2rem}.carousel-arrow-left{left:.5rem}.carousel-arrow-right{right:.5rem}.carousel-image-wrapper{min-height:300px}.carousel-image{max-height:400px}}.article{padding-top:6rem;padding-bottom:4rem;min-height:100vh}.article-loading,.article-error{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-secondary)}.article-navigation{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);transition:color .2s ease}.translate-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);transition:color .2s ease;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;font-size:.95rem;text-decoration:none}.translate-link:hover{color:var(--accent)}.translation-notice{background:var(--bg-secondary);color:var(--text-secondary);padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1.5rem;font-size:.9rem;display:inline-block}.article-header{margin-bottom:3rem}.article-title{font-size:3rem;margin-bottom:1rem;line-height:1.2}.article-meta{display:flex;gap:2rem;color:var(--text-secondary);flex-wrap:wrap;align-items:center}.article-translate{color:var(--accent);text-decoration:none;font-size:.9rem;transition:opacity .3s ease;display:inline-flex;align-items:center;gap:.25rem}.article-translate:hover{opacity:.8;text-decoration:underline}.article-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.article-tag{padding:.25rem .75rem;background:var(--bg-secondary);border-radius:1rem;font-size:.875rem;color:var(--text-secondary);font-weight:500;border:1px solid var(--border);text-decoration:none;transition:all .2s ease;display:inline-block}.article-tag:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:translateY(-1px);text-decoration:none}.article-thumbnail{margin-bottom:3rem;border-radius:1rem;overflow:hidden;max-width:800px;margin-left:auto;margin-right:auto;box-shadow:0 15px 40px #00000026;transition:transform .3s ease,box-shadow .3s ease;position:relative}.article-thumbnail:hover{transform:translateY(-3px);box-shadow:0 20px 50px #0003}.article-thumbnail img{width:100%;height:auto;display:block;max-height:400px;object-fit:cover;transition:transform .5s ease}.article-thumbnail:hover img{transform:scale(1.05)}[data-theme=light] .article-thumbnail{border:1px solid rgba(0,0,0,.05)}[data-theme=dark] .article-thumbnail{box-shadow:0 15px 40px #00000080}[data-theme=dark] .article-thumbnail:hover{box-shadow:0 20px 50px #000000b3}.article-content{max-width:800px;margin:0 auto;font-size:1.125rem;line-height:1.8}.article-content h2,.article-content h3,.article-content h4{margin-top:2rem;margin-bottom:1rem}.article-content p{margin-bottom:1.5rem}.article-content ul,.article-content ol{margin-bottom:1.5rem;padding-left:2rem}.article-content li{margin-bottom:.5rem}.article-content blockquote{margin:2rem 0;padding:1rem 2rem;border-left:4px solid var(--accent);background:var(--bg-secondary);font-style:italic}.article-content code{background:var(--bg-secondary);padding:.2rem .4rem;border-radius:.25rem;font-size:.9em}.article-content pre{background:var(--bg-secondary);padding:1rem;border-radius:.5rem;overflow-x:auto;margin-bottom:1.5rem}.article-content img{max-width:100%;height:auto;margin:3rem auto;border-radius:1rem;display:block;box-shadow:0 10px 30px #00000026;transition:transform .3s ease,box-shadow .3s ease;position:relative}.article-content img:hover{transform:translateY(-2px);box-shadow:0 15px 40px #0003}[data-theme=light] .article-content img{border:1px solid rgba(0,0,0,.05)}.article-content table{width:100%;max-width:100%;margin:2rem 0;border-collapse:separate;border-spacing:0;background:var(--bg-secondary);border-radius:.75rem;overflow:hidden;box-shadow:0 4px 12px #00000014;border:1px solid var(--border)}.article-content table thead{background:linear-gradient(135deg,var(--accent) 0%,rgba(102,126,234,.8) 100%);color:#fff}.article-content table th{padding:1rem 1.25rem;text-align:left;font-weight:600;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid rgba(255,255,255,.2)}.article-content table td{padding:1rem 1.25rem;border-bottom:1px solid var(--border);color:var(--text-primary);font-size:.95rem;line-height:1.6}.article-content table tbody tr{transition:background-color .2s ease}.article-content table tbody tr:hover{background:var(--bg-tertiary)}.article-content table tbody tr:last-child td{border-bottom:none}.article-content table td:first-child{font-weight:600;color:var(--text-secondary);white-space:nowrap}.article-content table td:last-child{color:var(--text-primary)}[data-theme=dark] .article-content table{box-shadow:0 4px 12px #0000004d}[data-theme=dark] .article-content img{box-shadow:0 10px 30px #00000080}[data-theme=dark] .article-content img:hover{box-shadow:0 15px 40px #000000b3}.article-content img{animation:fadeIn .5s ease-out}.article-content .photo-credit{font-size:.875rem;color:var(--text-secondary);text-align:center;margin-top:-2rem;margin-bottom:3rem;font-style:italic;opacity:.8}.article-content img+.photo-credit{margin-top:-2.5rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.draft-badge{position:fixed;top:80px;right:20px;background:#f44;color:#fff;padding:.5rem 1rem;border-radius:.5rem;font-weight:700;font-size:.875rem;z-index:100;box-shadow:0 4px 12px #ff44444d;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 4px 12px #ff44444d}50%{box-shadow:0 4px 20px #ff444480}to{box-shadow:0 4px 12px #ff44444d}}.drafts-notice{background:#f44;color:#fff;padding:1rem 2rem;border-radius:.5rem;margin-bottom:2rem;text-align:center;font-weight:500;display:block;width:100%}.article-content img[alt*=wide],.article-content img[alt*=Wide],.article-content img[alt*=banner],.article-content img[alt*=Banner]{max-width:calc(100% + 4rem);width:calc(100% + 4rem);margin-left:-2rem;margin-right:-2rem}@media (max-width: 768px){.article-title{font-size:2rem}.article-content{font-size:1rem}.article-content img{margin:2rem auto;border-radius:.75rem}.article-thumbnail:hover,.article-thumbnail:hover img,.article-content img:hover{transform:none}.article-content img[alt*=wide],.article-content img[alt*=Wide],.article-content img[alt*=banner],.article-content img[alt*=Banner]{max-width:100%;width:100%;margin-left:0;margin-right:0}.article-content table{font-size:.875rem;margin:1.5rem -1rem;width:calc(100% + 2rem);border-radius:0}.article-content table th,.article-content table td{padding:.75rem 1rem}.article-content table th{font-size:.85rem}.article-content table td:first-child{white-space:normal}}.translation-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.translation-modal{background:var(--bg-primary);border-radius:1rem;max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.translation-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border)}.translation-header h2{margin:0;font-size:1.75rem}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:.5rem;border-radius:.5rem;transition:all .2s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.close-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.translation-notice{background:var(--bg-secondary);padding:.75rem 2rem;font-size:.9rem;color:var(--text-secondary);border-bottom:1px solid var(--border)}.translation-content{padding:2rem 3rem;overflow-y:auto;flex:1;line-height:1.8;font-size:1.1rem}.translation-content h2,.translation-content h3,.translation-content h4{margin-top:2rem;margin-bottom:1rem}.translation-content p{margin-bottom:1.5rem}.translation-content ul,.translation-content ol{margin-bottom:1.5rem;padding-left:2rem}.translation-content li{margin-bottom:.5rem}.translation-content blockquote{margin:2rem 0;padding:1rem 2rem;border-left:4px solid var(--accent);background:var(--bg-secondary);font-style:italic}.translation-content img{max-width:100%;height:auto;margin:3rem auto;border-radius:1rem;display:block;box-shadow:0 10px 30px #00000026;transition:transform .3s ease,box-shadow .3s ease;position:relative;animation:fadeIn .5s ease-out}.translation-content img:hover{transform:translateY(-2px);box-shadow:0 15px 40px #0003}[data-theme=light] .translation-content img{border:1px solid rgba(0,0,0,.05)}[data-theme=dark] .translation-content img{box-shadow:0 10px 30px #00000080}[data-theme=dark] .translation-content img:hover{box-shadow:0 15px 40px #000000b3}@media (max-width: 768px){.translation-modal{max-height:calc(100vh - 2rem);margin:1rem;width:calc(100% - 2rem);border-radius:.75rem}.translation-overlay{padding:0;align-items:flex-start;padding-top:1rem;overflow-y:auto;-webkit-overflow-scrolling:touch}.translation-header{padding:1rem 1.5rem;position:sticky;top:0;background:var(--bg-primary);z-index:10}.translation-header h2{font-size:1.5rem}.translation-content{padding:1.5rem;overflow-y:auto;-webkit-overflow-scrolling:touch;max-height:calc(100vh - 8rem)}}.sanchez-page{padding-top:7rem;padding-bottom:2rem;min-height:100vh}.sanchez-header{margin-bottom:2rem}.page-title{font-size:2.5rem;margin-bottom:1rem}.sanchez-controls{margin-bottom:2rem}.filter-buttons{display:flex;gap:1rem;flex-wrap:wrap}.filter-buttons button{padding:.5rem 1rem;border:1px solid var(--text-secondary);background:transparent;color:var(--text-primary);border-radius:4px;cursor:pointer;transition:all .2s ease}.filter-buttons button:hover{background:var(--card-bg)}.filter-buttons button.active{background:var(--accent);color:#fff;border-color:var(--accent)}[data-theme=light] .filter-buttons button.active{background:#0052a3;border-color:#0052a3;box-shadow:0 2px 4px #0000001a}.sanchez-badges{display:flex;gap:.5rem;margin-bottom:.5rem;align-items:center}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-draft{background:#f59e0b;color:#fff}.status-published{background:#10b981;color:#fff}.translation-indicator{font-size:1.2rem}.no-posts{text-align:center;padding:3rem;color:var(--text-secondary)}.back-link{display:inline-block;margin-bottom:2rem;color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.password-container{max-width:400px;margin:4rem auto;text-align:center}.password-form{display:flex;gap:1rem;margin-top:2rem}.password-input{flex:1;padding:.75rem 1rem;font-size:1rem;border:2px solid var(--border);border-radius:4px;background:var(--card-bg);color:var(--text-primary);transition:border-color .2s ease}.password-input:focus{outline:none;border-color:var(--accent)}.password-submit{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.password-submit:hover{background:var(--accent-hover);transform:translateY(-1px)}[data-theme=light] .password-submit{background:#0052a3}[data-theme=light] .password-submit:hover{background:#003d7a}@media (max-width: 768px){.sanchez-table-container{padding:.5rem}.sanchez-table th,.sanchez-table td{padding:.5rem;font-size:.875rem}.page-title{font-size:2rem}.password-form{flex-direction:column}.password-submit{width:100%}}.unsubscribe-container{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:2rem}.unsubscribe-content{max-width:400px;width:100%;text-align:center}.unsubscribe-content h1{font-size:2rem;margin-bottom:1rem;color:var(--text-primary)}.unsubscribe-content p{margin-bottom:2rem;color:var(--text-secondary)}.unsubscribe-content form{text-align:left}.form-group{margin-bottom:1.5rem}.form-group input{width:100%;padding:.75rem;font-size:1rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-secondary);color:var(--text-primary);transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary-color)}.unsubscribe-button{width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#fff;background-color:#dc3545;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.unsubscribe-button:hover{background-color:#c82333}.home-link{display:inline-block;margin-top:1rem;color:var(--primary-color);text-decoration:none}.home-link:hover{text-decoration:underline}.confirm-container{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:2rem}.confirm-content{max-width:500px;width:100%;text-align:center;padding:3rem;background:var(--bg-secondary);border-radius:12px;box-shadow:0 4px 6px #0000001a}.confirm-content h1{font-size:2rem;margin-bottom:1rem;color:var(--text-primary)}.confirm-content p{margin-bottom:1.5rem;color:var(--text-secondary);line-height:1.6}.confirm-content strong{color:var(--text-primary)}.spinner{width:50px;height:50px;margin:0 auto 2rem;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.success-icon{font-size:60px;margin-bottom:1rem}.confirm-content.success{border:2px solid #48bb78}.redirect-message{font-size:.875rem;color:var(--text-tertiary);font-style:italic}.error-icon{font-size:60px;margin-bottom:1rem}.confirm-content.error{border:2px solid #f56565}.home-link{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background-color:var(--primary-color);color:#fff;text-decoration:none;border-radius:6px;font-weight:500;transition:background-color .2s}.home-link:hover{background-color:var(--primary-hover)}.newsletter-success{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:4rem 0}.success-content{text-align:center;max-width:600px;margin:0 auto}.success-content h1{color:var(--color-primary);margin-bottom:2rem}.success-icon{font-size:4rem;margin-bottom:2rem}.success-message{font-size:1.25rem;margin-bottom:1.5rem;color:var(--color-text)}.success-note{color:var(--color-text-secondary);margin-bottom:2rem}.success-content .button{display:inline-block;background:var(--color-primary);color:#fff;padding:.75rem 2rem;text-decoration:none;border-radius:6px;transition:all .3s ease}.success-content .button:hover{background:var(--color-primary-dark);transform:translateY(-2px)}.newsletter-page{padding-top:6rem;padding-bottom:4rem;min-height:100vh}.newsletter-header{max-width:600px;margin-bottom:3rem}.newsletter-header h1{font-size:3rem;margin-bottom:1rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.newsletter-subtitle{font-size:1.25rem;color:var(--text-secondary);line-height:1.6}.newsletter-form{max-width:600px;display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.required{color:#e53e3e}.form-group input{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:inherit;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.375rem;color:var(--text-primary);transition:border-color .2s ease,background-color .2s ease}.form-group input:focus{outline:none;border-color:var(--accent);background:var(--bg-tertiary)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.submit-button{display:inline-block;padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background .2s ease;margin-top:1rem}.submit-button:hover:not(:disabled){background:var(--accent-hover)}.submit-button:disabled{opacity:.7;cursor:not-allowed}.error-message{color:#e53e3e;text-align:center;margin-top:1rem;font-size:.95rem}.newsletter-success{max-width:600px;text-align:center;padding:2rem 0}.success-icon{font-size:4rem;margin-bottom:1rem}.newsletter-success h2{color:var(--text-color);margin-bottom:1rem}.newsletter-success p{color:var(--text-secondary);line-height:1.6}.success-note{margin-top:.5rem;font-size:.95rem}.newsletter-footer{max-width:600px;margin-top:3rem;text-align:center}.privacy-note{font-size:.875rem;color:var(--text-secondary)}@media (max-width: 768px){.newsletter-header h1{font-size:2rem}.newsletter-subtitle{font-size:1.1rem}}.inah-page{padding-top:6rem;min-height:100vh}.back-link{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:2rem;color:var(--text-secondary);transition:color .2s ease}.page-title{font-size:3rem;margin-bottom:1rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:1rem}.inah-header{text-align:center;margin-bottom:3rem}.inah-stats{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;color:var(--text-primary)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-main{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-number{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:inherit}.stat-label{font-size:.9rem;opacity:.9;text-transform:uppercase;letter-spacing:1px;color:inherit}.stat-progress{width:100%;height:8px;background:#ffffff4d;border-radius:4px;margin-top:1rem;overflow:hidden}.stat-progress-bar{height:100%;background:#fff;border-radius:4px;transition:width .5s ease}.stat-percentage{margin-top:.5rem;font-size:.9rem;opacity:.9}.inah-controls{display:grid;grid-template-columns:1fr 1fr auto;gap:1rem;margin-bottom:2rem;align-items:center}.control-group{display:flex;gap:.5rem}.inah-search{width:100%;padding:.75rem 1rem;border:2px solid var(--border);border-radius:8px;font-size:1rem;transition:border-color .2s;background:var(--card-bg);color:var(--text-primary)}.inah-search:focus{outline:none;border-color:var(--accent)}.inah-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:2px solid var(--border);border-radius:8px;font-size:1rem;background:var(--card-bg);color:var(--text-primary);cursor:pointer;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.5em}@media (prefers-color-scheme: dark){.inah-select{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a0a0a0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")}}.inah-select:focus{outline:none;border-color:var(--accent)}.control-buttons{display:flex;gap:.5rem}.filter-btn,.view-btn{padding:.75rem 1rem;border:2px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text-primary);cursor:pointer;transition:all .2s;font-size:1rem}.filter-btn:hover{border-color:var(--accent);opacity:.8}.filter-btn.active,.view-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.inah-results{margin-bottom:1.5rem;color:var(--text-secondary);font-size:.95rem}.inah-sites.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.site-card{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .3s;position:relative;display:flex;flex-direction:column}.site-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.site-card.visited{background:linear-gradient(to bottom,rgba(102,126,234,.05),var(--card-bg));border:2px solid var(--accent);box-shadow:0 0 0 1px var(--accent) inset}.site-image{position:relative;width:100%;height:200px;overflow:hidden;background:#f0f0f0;border-radius:12px 12px 0 0}.site-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.site-card:hover .site-image img{transform:scale(1.05)}.site-image-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.site-image-text{text-align:center;color:#fff;padding:1rem}.site-image-icon{font-size:3rem;margin-bottom:.5rem;opacity:.9}.site-image-name{font-size:1.1rem;font-weight:600;margin-bottom:.25rem;line-height:1.2}.site-image-state{font-size:.85rem;opacity:.8;text-transform:uppercase;letter-spacing:1px}.site-card:hover .site-image-placeholder{background:linear-gradient(135deg,#764ba2,#667eea)}.site-status{position:absolute;top:1rem;right:1rem}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.abierto{background:var(--accent);color:#fff}.status-badge.cerrado{background:#dc2626;color:#fff}.status-badge.desconocido{background:#64748b;color:#fff}.site-content{padding:1.25rem 1.25rem 3rem;position:relative;display:flex;flex-direction:column;flex:1}.site-name{font-size:1.2rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.site-state{color:#667eea;font-weight:600;font-size:.9rem;margin-bottom:.5rem}.site-location{color:var(--text-secondary);font-size:.85rem;margin-top:.5rem;line-height:1.4;min-height:5.5rem}.visited-badge{display:inline-block;padding:.25rem .75rem;background:var(--accent);color:#fff;border-radius:20px;font-size:.8rem;font-weight:600;position:absolute;bottom:1.25rem;left:1.25rem;width:fit-content}.blog-post-badge{display:inline-block;padding:.25rem .75rem;background:#10b981;color:#fff;border-radius:20px;font-size:.8rem;font-weight:600;position:absolute;bottom:1.25rem;right:1.25rem;width:fit-content;transition:transform .2s}.site-card.has-blog-post{cursor:pointer;text-decoration:none}.site-card.has-blog-post:hover .blog-post-badge{transform:scale(1.05)}.site-card.has-blog-post .site-content{padding-bottom:3.5rem}.no-results{text-align:center;padding:4rem 2rem;color:#666}@media (max-width: 768px){.page-title{font-size:2rem}.page-subtitle{font-size:1.1rem}.inah-stats,.inah-controls{grid-template-columns:1fr;gap:1rem}.control-buttons{justify-content:flex-end}.inah-sites.grid{grid-template-columns:1fr}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.rsvp-standalone{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.rsvp-loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff;gap:20px}.rsvp-loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.rsvp-loading-screen p{font-size:1.1em;opacity:.8}.rsvp-error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff;text-align:center;padding:20px}.rsvp-error-icon{font-size:4em;margin-bottom:20px}.rsvp-error-screen h1{font-size:2em;margin-bottom:10px}.rsvp-error-screen p{opacity:.7;font-size:1.1em}.rsvp-hero{position:relative;height:45vh;min-height:350px;max-height:500px;display:flex;align-items:flex-end;overflow:hidden}.rsvp-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;transform:scale(1.1);animation:heroZoom 20s ease-in-out infinite alternate}@keyframes heroZoom{0%{transform:scale(1.1)}to{transform:scale(1.15)}}.rsvp-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#1a1a2e4d,#1a1a2e99,#1a1a2ef2)}.rsvp-hero-content{position:relative;z-index:2;padding:40px 20px 60px;width:100%;max-width:700px;margin:0 auto}.rsvp-hero-title{font-size:clamp(1.8em,5vw,3em);font-weight:800;color:#fff;margin:0 0 15px;text-shadow:0 2px 20px rgba(0,0,0,.5);line-height:1.2}.rsvp-hero-date{display:flex;align-items:center;gap:10px;color:#fff;font-size:1.1em;font-weight:600;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 20px;border-radius:8px}.rsvp-lang-btn{position:absolute;top:20px;right:20px;z-index:10;padding:10px 18px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:30px;color:#fff;font-size:.95em;font-weight:600;cursor:pointer;transition:all .3s ease}.rsvp-lang-btn:hover{background:#ffffff40;transform:translateY(-2px)}.rsvp-main-content{position:relative;z-index:3;margin-top:-40px;padding:0 20px 40px}.rsvp-card{max-width:700px;margin:0 auto;background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.rsvp-section{padding:30px;border-bottom:1px solid #eee}.rsvp-section:last-child{border-bottom:none}.rsvp-section-title{font-size:.85em;font-weight:700;color:#111!important;margin:0 0 16px;text-transform:uppercase;letter-spacing:1px}.rsvp-section-highlight{background:linear-gradient(135deg,#f8f9fc,#fff)}.rsvp-event-text{font-size:1.05em;line-height:1.8;color:#444}.rsvp-event-text p{margin:0 0 1em}.rsvp-event-text p:last-child{margin-bottom:0}.rsvp-event-text ul,.rsvp-event-text ol{margin:.5em 0 1em;padding-left:1.5em}.rsvp-event-text li{margin-bottom:.3em}.rsvp-event-text a{color:#667eea;text-decoration:underline}.rsvp-event-text strong{font-weight:600}.rsvp-event-text em{font-style:italic}.rsvp-map-wrapper{border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a;margin-bottom:20px}.rsvp-map-wrapper .leaflet-container{height:250px!important}.rsvp-venue-info{display:flex;flex-direction:column;gap:8px;padding:20px;background:#f8f9fa;border-radius:12px}.rsvp-venue-info strong{font-size:1.1em;color:#1a1a2e}.rsvp-venue-address{color:#666;font-size:.95em}.rsvp-directions-btn{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:25px;font-weight:600;font-size:.95em;transition:all .3s ease;width:fit-content}.rsvp-directions-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.rsvp-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}.rsvp-info-item{display:flex;gap:12px;align-items:flex-start}.rsvp-info-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff}.rsvp-info-content{display:flex;flex-direction:column;gap:4px}.rsvp-info-label{font-size:.8em;font-weight:600;color:#1a1a2e;text-transform:uppercase;letter-spacing:.5px}.rsvp-info-value{font-size:1em;font-weight:600;color:#1a1a2e}.rsvp-info-subvalue{font-size:.9em;color:#666}.rsvp-directions-link{display:inline-flex;align-items:center;gap:8px;margin-top:15px;color:#667eea;font-weight:600;font-size:.95em;text-decoration:none;transition:color .2s}.rsvp-directions-link:hover{color:#764ba2}.rsvp-action-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px;justify-content:center}.rsvp-action-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;font-size:.95em;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s ease;border:none;font-family:inherit}.rsvp-action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.rsvp-action-directions{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.rsvp-action-directions:hover{background:linear-gradient(135deg,#5a6fd6,#6a4190)}.rsvp-action-google{background:#fff;color:#4285f4;border:2px solid #4285f4}.rsvp-action-google:hover{background:#4285f4;color:#fff}.rsvp-action-apple{background:#fff;color:#1a1a2e;border:2px solid #1a1a2e}.rsvp-action-apple:hover{background:#1a1a2e;color:#fff}.rsvp-action-buttons-light{margin-top:0}.rsvp-action-btn-light{background:#fff;color:#1a1a2e;border:none;box-shadow:0 4px 15px #0003}.rsvp-action-btn-light:hover{background:#f0f0f0;box-shadow:0 8px 25px #0000004d}@media (max-width: 768px){.rsvp-action-buttons{flex-direction:column}.rsvp-action-btn{justify-content:center;width:100%}}.rsvp-form-section{background:linear-gradient(135deg,#fafbfc,#fff)}.rsvp-status-message{text-align:center;padding:40px 20px;border-radius:16px}.rsvp-status-icon{font-size:3em;margin-bottom:15px}.rsvp-status-message h3{font-size:1.4em;color:#1a1a2e;margin:0 0 10px}.rsvp-status-message p{color:#666;margin:0;font-size:1.05em}.rsvp-status-closed{background:linear-gradient(135deg,#fff5f5,#fff);border:2px solid #fed7d7}.rsvp-status-full{background:linear-gradient(135deg,#fffaf0,#fff);border:2px solid #feebc8}.rsvp-modern-form{display:flex;flex-direction:column;gap:25px}.rsvp-decision-group{text-align:center}.rsvp-decision-label{font-size:1.15em;font-weight:600;color:#1a1a2e;margin:0 0 20px}.rsvp-decision-buttons{display:flex;gap:15px;justify-content:center}.rsvp-decision-btn{flex:1;padding:16px 24px;border:2px solid #e2e8f0;border-radius:8px;background:#f7fafc;cursor:pointer;transition:all .2s ease;font-size:1em;font-weight:600;color:#4a5568}.rsvp-decision-btn:hover{border-color:#667eea;background:#edf2f7}.rsvp-decision-yes.active{background:#48bb78;border-color:#48bb78;color:#fff}.rsvp-decision-yes.active:hover{background:#38a169;border-color:#38a169}.rsvp-decision-no.active{background:#e53e3e;border-color:#e53e3e;color:#fff}.rsvp-decision-no.active:hover{background:#c53030;border-color:#c53030}.rsvp-form-fields-modern{display:flex;flex-direction:column;gap:20px;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.rsvp-input-group{display:flex;flex-direction:column;gap:8px}.rsvp-input-group label{font-weight:600;color:#4a5568;font-size:.9em}.rsvp-input,.rsvp-select,.rsvp-textarea{width:100%;padding:14px 18px;border:2px solid #e2e8f0;border-radius:12px;font-size:1em;font-family:inherit;background:#fff;color:#1a1a2e;transition:all .2s ease;box-sizing:border-box}.rsvp-input:focus,.rsvp-select:focus,.rsvp-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea26}.rsvp-input::placeholder,.rsvp-textarea::placeholder{color:#a0aec0}.rsvp-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:45px}.rsvp-textarea{resize:vertical;min-height:100px}.rsvp-submit-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s ease;margin-top:10px}.rsvp-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.rsvp-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.rsvp-submit-icon{font-size:1.2em}.rsvp-submit-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.rsvp-form-error-modern{display:flex;align-items:center;gap:10px;padding:14px 18px;background:#fff5f5;border:1px solid #feb2b2;border-radius:12px;color:#c53030;font-size:.95em}.rsvp-footer{text-align:center;padding:30px 20px;color:#fff9;font-size:.9em}.rsvp-footer a{color:#fffc;text-decoration:none;font-weight:600;transition:color .2s}.rsvp-footer a:hover{color:#fff}.rsvp-hero-compact{height:30vh;min-height:200px;max-height:300px}.rsvp-confirmation-header{text-align:center;padding:40px 30px;background:linear-gradient(135deg,#f0fff4,#fff)}.rsvp-confirmation-badge{width:80px;height:80px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;font-size:2.5em;border-radius:50%;animation:popIn .5s ease-out}@keyframes popIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.rsvp-badge-yes{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);box-shadow:0 8px 30px #48bb784d}.rsvp-badge-no{background:linear-gradient(135deg,#e2e8f0,#cbd5e0);box-shadow:0 8px 30px #a0aec04d}.rsvp-confirmation-main-title{font-size:1.8em;font-weight:800;color:#1a1a2e!important;margin:0 0 15px}.rsvp-confirmation-attendee-name{font-size:1.15em;color:#4a5568!important;margin:0;line-height:1.6}.rsvp-confirmation-attendee-name strong{color:#1a1a2e!important}.rsvp-confirmation-message-text{font-size:1.05em;color:#4a5568!important;margin:10px 0 0}.rsvp-calendar-section-modern{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center}.rsvp-calendar-alert{display:flex;align-items:center;justify-content:center;gap:10px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:15px 20px;border-radius:12px;margin-bottom:20px}.rsvp-calendar-alert-icon{font-size:1.3em}.rsvp-calendar-alert p{margin:0;font-size:.95em;font-weight:500}.rsvp-calendar-title{font-size:1.4em;margin:0 0 20px;font-weight:700}.rsvp-calendar-buttons-modern{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.rsvp-calendar-btn-modern{display:flex;align-items:center;gap:10px;padding:14px 24px;border-radius:12px;font-size:1em;font-weight:600;text-decoration:none;cursor:pointer;transition:all .3s ease;border:none;box-shadow:0 4px 15px #0003}.rsvp-calendar-btn-modern:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0000004d}.rsvp-calendar-google{background:#fff;color:#4285f4}.rsvp-calendar-apple{background:#fff;color:#1a1a2e}.rsvp-calendar-btn-icon{font-size:1.2em}.rsvp-details-section{background:#fff}.rsvp-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.rsvp-detail-card{display:flex;gap:15px;padding:20px;background:linear-gradient(135deg,#f8f9fa,#fff);border-radius:12px;border:1px solid #e2e8f0}.rsvp-detail-icon{font-size:1.8em;flex-shrink:0}.rsvp-detail-content{display:flex;flex-direction:column;gap:4px}.rsvp-detail-label{font-size:.85em;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#1a1a2e}.rsvp-detail-value{font-size:1.05em;font-weight:600;color:#1a1a2e}.rsvp-detail-subvalue{font-size:.9em;color:#666}@media (max-width: 768px){.rsvp-hero{height:40vh;min-height:300px}.rsvp-hero-content{padding:30px 15px}.rsvp-hero-title{font-size:1.6em}.rsvp-hero-date{font-size:.95em;padding:8px 16px}.rsvp-lang-btn{top:15px;right:15px;padding:8px 14px;font-size:.85em}.rsvp-main-content{margin-top:-30px;padding:0 15px 30px}.rsvp-card{border-radius:20px}.rsvp-section{padding:25px 20px}.rsvp-section-title{font-size:1em}.rsvp-decision-buttons{flex-direction:column}.rsvp-info-grid{grid-template-columns:1fr}.rsvp-hero-compact{height:25vh;min-height:180px}.rsvp-confirmation-header{padding:30px 20px}.rsvp-confirmation-badge{width:70px;height:70px;font-size:2em}.rsvp-confirmation-main-title{font-size:1.5em}.rsvp-calendar-buttons-modern{flex-direction:column}.rsvp-calendar-btn-modern{justify-content:center}.rsvp-details-grid{grid-template-columns:1fr}}@media (max-width: 480px){.rsvp-hero{height:35vh;min-height:250px}.rsvp-hero-title{font-size:1.4em}.rsvp-section{padding:20px 15px}.rsvp-input,.rsvp-select,.rsvp-textarea{padding:12px 14px}.rsvp-submit-btn{padding:14px 20px;font-size:1em}}.rsvp-auth-container{max-width:400px;margin-top:60px}.rsvp-auth-form{text-align:center;padding:40px 20px}.rsvp-auth-form h1{margin-bottom:10px}.rsvp-auth-form p{color:var(--text-secondary, #666);margin-bottom:30px}.rsvp-auth-form form{display:flex;flex-direction:column;gap:15px}.rsvp-password-input{width:100%;padding:12px;border:1px solid var(--border);border-radius:6px;font-size:1em;background:var(--bg-secondary);color:var(--text-primary);box-sizing:border-box}.rsvp-password-input:focus{outline:none;border-color:var(--accent);background:var(--bg-tertiary)}.rsvp-page{min-height:100vh;background:var(--bg-primary);padding-top:6rem;padding-left:20px;padding-right:20px;padding-bottom:20px}.rsvp-container{max-width:600px;margin:0 auto;padding:20px;background:var(--card-bg, #fff);border-radius:12px;box-shadow:0 2px 8px #0000001a;position:relative}.rsvp-lang-toggle{position:absolute;top:20px;right:20px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:.9em;font-weight:600;cursor:pointer;transition:all .2s;z-index:10;box-shadow:0 2px 4px #0000001a}.rsvp-lang-toggle:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.rsvp-lang-toggle:active{transform:translateY(0)}.rsvp-header{text-align:center;margin-bottom:20px}.rsvp-banner{max-width:100%;border-radius:12px;margin-bottom:10px}.rsvp-title{font-size:1.5em;margin:10px 0;color:var(--text-primary, #000)}.rsvp-date{color:var(--text-secondary, #666);margin-bottom:20px;font-size:.95em}.rsvp-description{margin:20px 0;line-height:1.6;color:var(--text-primary, #333)}.rsvp-map{margin:20px 0;border:1px solid var(--border, #ccc);border-radius:8px;overflow:hidden}.rsvp-map .leaflet-container{height:300px;width:100%;border-radius:8px}.rsvp-map .leaflet-control-zoom a,.rsvp-map .leaflet-control-attribution{color:#333}[data-theme=dark] .rsvp-map .leaflet-tile{filter:brightness(.8) invert(1) contrast(1.2) hue-rotate(200deg) saturate(.5)}.rsvp-venue{margin-top:12px;color:var(--text-primary, #444);font-size:.95em;line-height:1.5}.rsvp-venue-link{margin-top:8px}.rsvp-venue-link a{color:var(--accent);text-decoration:underline}.rsvp-form{margin-top:30px}.rsvp-capacity-warning{padding:12px;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;margin-bottom:20px;text-align:center;color:#856404}.rsvp-buttons{display:flex;gap:10px;margin:20px 0}.rsvp-button{flex:1;padding:14px;font-size:1.05em;border-radius:8px;border:2px solid transparent;cursor:pointer;font-weight:500;transition:all .2s;background:var(--button-bg, #e9ecef);color:var(--button-text, #333)}.rsvp-button-yes{background:#e8f5e9;border-color:#c8e6c9;color:#2e7d32}.rsvp-button-yes:hover{background:#c8e6c9}.rsvp-button-yes.active{background:#28a745;border-color:#28a745;color:#fff}.rsvp-button-no{background:#ffebee;border-color:#ffcdd2;color:#c62828}.rsvp-button-no:hover{background:#ffcdd2}.rsvp-button-no.active{background:#dc3545;border-color:#dc3545;color:#fff}.rsvp-form-fields{margin-top:20px;animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.rsvp-form-group{margin-bottom:16px}.rsvp-form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-primary);font-size:.95em}.rsvp-form-group input,.rsvp-form-group select,.rsvp-form-group textarea{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:inherit;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.375rem;color:var(--text-primary);transition:border-color .2s ease,background-color .2s ease;box-sizing:border-box}.rsvp-form-group input:focus,.rsvp-form-group select:focus,.rsvp-form-group textarea:focus{outline:none;border-color:var(--accent);background:var(--bg-tertiary)}.rsvp-form-hint{display:block;margin-top:4px;font-size:.85em;color:var(--text-secondary, #666)}.rsvp-input-error{border-color:#dc3545!important}.rsvp-input-error:focus{border-color:#dc3545!important;box-shadow:0 0 0 3px #dc354526!important}small.rsvp-form-error{display:block;margin-top:4px;font-size:.85em;color:#dc3545;padding:0;background:none;border:none}.rsvp-submit{width:100%;padding:14px;background:var(--primary-color, #007bff);color:#fff;border:none;border-radius:8px;font-size:1.05em;font-weight:500;cursor:pointer;transition:background .2s}.rsvp-submit:hover{background:var(--primary-hover, #0056b3)}.rsvp-submit:disabled{background:var(--disabled-bg, #ccc);cursor:not-allowed}.rsvp-form-error{margin-top:12px;padding:10px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-size:.9em}.rsvp-confirmation,.rsvp-closed{margin-top:30px;padding:30px;text-align:center;background:var(--card-bg, #f8f9fa);border-radius:8px}.rsvp-confirmation-icon{font-size:3em;color:#28a745;margin-bottom:10px}.rsvp-confirmation h2,.rsvp-closed h2{margin:10px 0;color:var(--text-primary, #000)}.rsvp-confirmation p,.rsvp-closed p{color:var(--text-secondary, #666);line-height:1.6}.rsvp-loading,.rsvp-error,.rsvp-empty{padding:40px 20px;text-align:center;color:var(--text-secondary, #666)}.rsvp-error{color:#dc3545}.rsvp-admin{min-height:100vh;background:var(--bg-primary);padding-top:6rem;padding-left:20px;padding-right:20px;padding-bottom:20px}.rsvp-admin .rsvp-container{max-width:1200px}.rsvp-admin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;gap:20px;flex-wrap:wrap}.rsvp-admin .page-title,.rsvp-page .page-title{font-size:3rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.rsvp-admin .page-subtitle,.rsvp-page .page-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:0}.rsvp-title-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:2rem}.rsvp-title-header>a{flex-shrink:0}.rsvp-admin-actions{display:flex;gap:10px;flex-wrap:wrap}.back-link{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:2rem;color:var(--text-secondary);transition:color .2s ease;text-decoration:none}.back-link:hover{color:var(--accent)}.rsvp-button-primary{background:var(--primary-color, #007bff);color:#fff;padding:10px 20px;border:none;border-radius:6px;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s;white-space:nowrap}.rsvp-button-primary:hover{background:var(--primary-hover, #0056b3)}.rsvp-button-secondary{background:var(--secondary-bg, #6c757d);color:#fff;padding:10px 20px;border:none;border-radius:6px;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s;white-space:nowrap}.rsvp-button-secondary:hover{background:#5a6268}.rsvp-button-sm{padding:8px 16px;font-size:.9em;flex-shrink:0;white-space:nowrap;width:auto;max-width:150px}.rsvp-button-danger{background:#dc3545;color:#fff;padding:10px 20px;border:none;border-radius:6px;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s;white-space:nowrap}.rsvp-button-danger:hover{background:#c82333}.rsvp-admin-table{width:100%;border-collapse:collapse;background:var(--card-bg, #fff);border-radius:8px;overflow:hidden}.rsvp-admin-table th,.rsvp-admin-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border, #e9ecef)}.rsvp-admin-table th{background:var(--table-header-bg, #f8f9fa);font-weight:600;color:var(--text-primary, #333);font-size:.9em}.rsvp-admin-table tbody tr:hover{background:var(--hover-bg, #f8f9fa)}.rsvp-event-slug{font-size:.85em;color:var(--text-secondary, #666);font-family:monospace}.rsvp-event-expired{opacity:.6}.rsvp-status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.85em;font-weight:500}.rsvp-status-badge.active{background:#d4edda;color:#155724}.rsvp-status-badge.expired{background:#f8d7da;color:#721c24}.rsvp-status-toggle{display:inline-block;padding:6px 14px;border-radius:12px;font-size:.85em;font-weight:500;border:none;cursor:pointer;transition:all .2s;font-family:inherit}.rsvp-status-toggle:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.rsvp-status-toggle:active:not(:disabled){transform:translateY(0)}.rsvp-status-toggle:disabled{cursor:not-allowed;opacity:.8}.rsvp-status-active{background:#d4edda;color:#155724}.rsvp-status-active:hover:not(:disabled){background:#c3e6cb}.rsvp-status-inactive{background:#f8d7da;color:#721c24}.rsvp-status-inactive:hover:not(:disabled){background:#f5c6cb}.rsvp-status-passed{background:#e2e3e5;color:#6c757d}.rsvp-number-positive{color:#28a745;font-weight:600}.rsvp-number-negative{color:#dc3545;font-weight:600}.rsvp-number-warning{color:#ffc107;font-weight:600}.rsvp-text-muted{color:var(--text-secondary, #999);font-style:italic}.rsvp-link-button{color:var(--link-color, #007bff);text-decoration:none;font-size:.9em}.rsvp-link-button:hover{text-decoration:underline}.rsvp-actions-cell{display:flex;gap:8px;flex-wrap:nowrap}.rsvp-action-link{display:inline-block;padding:4px 10px;font-size:.85em;text-decoration:none;border-radius:4px;background:var(--bg-secondary, #f0f0f0);color:var(--text-primary, #333);transition:background .2s,color .2s;white-space:nowrap}.rsvp-action-link:hover{background:var(--primary-color, #007bff);color:#fff}.rsvp-action-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;font-size:1.1em;text-decoration:none;border-radius:6px;background:var(--bg-secondary, #f0f0f0);transition:transform .15s,background .2s}.rsvp-action-icon:hover{background:var(--bg-tertiary, #e0e0e0);transform:scale(1.1)}.rsvp-admin-form{background:var(--bg-secondary);padding:30px;border-radius:8px}.rsvp-form-section{margin-bottom:30px;padding-bottom:30px;border-bottom:1px solid var(--border, #e9ecef)}.rsvp-form-section:last-of-type{border-bottom:none}.rsvp-form-section h2{margin-bottom:20px;color:var(--text-primary);font-size:1.3em}.rsvp-collapsible-header{width:100%;background:var(--bg-tertiary);border:1px solid var(--border);padding:15px 20px;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s;margin-bottom:15px;font-size:1.1em;font-weight:500;color:var(--text-primary);text-align:left}.rsvp-collapsible-header:hover{background:var(--bg-secondary);border-color:var(--accent)}.rsvp-collapsible-header span{display:flex;align-items:center;gap:8px}.rsvp-collapsible-header small{color:var(--text-secondary);font-weight:400;font-size:.85em}.rsvp-collapsible-content{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.rsvp-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.rsvp-form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:30px}.rsvp-admin-event-info{background:var(--info-bg, #f8f9fa);padding:20px;border-radius:8px;margin-bottom:20px}.rsvp-admin-info-item{margin-bottom:10px;font-size:.95em}.rsvp-admin-info-item:last-child{margin-bottom:0}.rsvp-admin-info-item strong{color:var(--text-primary, #333)}.rsvp-admin-info-item a{color:var(--link-color, #007bff);text-decoration:none;word-break:break-all}.rsvp-admin-info-item a:hover{text-decoration:underline}.rsvp-admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:30px}.rsvp-stat-card{background:var(--card-bg, #fff);padding:20px;border-radius:8px;text-align:center;border:2px solid var(--border, #e9ecef)}.rsvp-stat-card.rsvp-stat-positive{border-color:#28a745}.rsvp-stat-card.rsvp-stat-negative{border-color:#dc3545}.rsvp-stat-number{font-size:2em;font-weight:700;color:var(--text-primary, #000);margin-bottom:5px}.rsvp-stat-label{font-size:.9em;color:var(--text-secondary, #666)}.rsvp-admin-filter{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.rsvp-filter-btn{padding:8px 16px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);border-radius:6px;cursor:pointer;font-size:.9em;transition:all .2s}.rsvp-filter-btn:hover{background:var(--bg-tertiary)}.rsvp-filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.rsvp-admin-table-container{overflow-x:auto;margin-bottom:20px}.rsvp-row-yes{background:#28a7450d}.rsvp-row-no{background:#dc35450d}.rsvp-decision-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.85em;font-weight:500}.rsvp-decision-yes{background:#d4edda;color:#155724}.rsvp-decision-no{background:#f8d7da;color:#721c24}.rsvp-delete-btn{background:transparent;border:none;color:var(--text-secondary, #999);cursor:pointer;font-size:1.2em;padding:4px 8px;transition:color .2s}.rsvp-delete-btn:hover{color:#dc3545}[data-theme=dark] .rsvp-page,[data-theme=dark] .rsvp-admin{background:#1a1a1a}[data-theme=dark] .rsvp-container,[data-theme=dark] .rsvp-admin-table,[data-theme=dark] .rsvp-admin-form,[data-theme=dark] .rsvp-stat-card{background:#2a2a2a;color:#e0e0e0}[data-theme=dark] .rsvp-title,[data-theme=dark] .rsvp-admin-title,[data-theme=dark] .rsvp-stat-number,[data-theme=dark] h2{color:#e0e0e0}[data-theme=dark] .rsvp-date,[data-theme=dark] .rsvp-admin-subtitle,[data-theme=dark] .rsvp-text-muted,[data-theme=dark] .rsvp-stat-label{color:#999}[data-theme=dark] .rsvp-admin-table th{background:#1a1a1a}[data-theme=dark] .rsvp-admin-table tbody tr:hover{background:#333}[data-theme=dark] .rsvp-admin-event-info{background:#1a1a1a}.rsvp-confirmation-page{margin-top:20px}.rsvp-confirmation-icon-large{font-size:4em;color:#28a745;text-align:center;margin-bottom:20px;animation:scaleIn .4s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.rsvp-confirmation-title{text-align:center;color:var(--text-primary, #000);margin-bottom:20px;font-size:1.8em}.rsvp-confirmation-message{text-align:center;margin-bottom:30px;padding:20px;background:var(--bg-secondary, #f8f9fa);border-radius:8px}.rsvp-confirmation-attendee{font-size:1.1em;margin-bottom:10px;color:var(--text-primary, #333)}.rsvp-confirmation-details{color:var(--text-secondary, #666);line-height:1.6}.rsvp-calendar-section{background:linear-gradient(135deg,#667eea,#764ba2);padding:30px;border-radius:12px;margin:30px 0;color:#fff;box-shadow:0 4px 12px #00000026}.rsvp-calendar-heading{color:#fff;margin-bottom:10px;font-size:1.5em;text-align:center}.rsvp-calendar-important{text-align:center;margin-bottom:20px;font-size:.95em;background:#ffffff26;padding:12px;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.rsvp-calendar-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.rsvp-calendar-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;border-radius:8px;font-size:1em;font-weight:600;text-decoration:none;transition:all .2s;border:none;cursor:pointer;box-shadow:0 2px 8px #0003}.rsvp-calendar-btn-google{background:#fff;color:#4285f4}.rsvp-calendar-btn-google:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 12px #00000040}.rsvp-calendar-btn-apple{background:#fff;color:#000}.rsvp-calendar-btn-apple:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 12px #00000040}.rsvp-calendar-icon{font-size:1.3em}.rsvp-event-details{background:var(--bg-secondary, #f8f9fa);padding:25px;border-radius:8px;margin:25px 0}.rsvp-event-details h3{margin-bottom:20px;color:var(--text-primary, #000);font-size:1.3em;border-bottom:2px solid var(--accent);padding-bottom:10px}.rsvp-detail-item{margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--border, #e9ecef)}.rsvp-detail-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.rsvp-detail-item strong{display:block;color:var(--accent);margin-bottom:6px;font-size:.9em;text-transform:uppercase;letter-spacing:.5px}.rsvp-detail-item p{margin:0;color:var(--text-primary, #333);line-height:1.6}.rsvp-event-description{margin:25px 0;padding:20px;background:var(--card-bg, #fff);border-left:4px solid var(--accent);border-radius:4px;color:var(--text-primary, #333);line-height:1.7}[data-theme=dark] .rsvp-confirmation-message,[data-theme=dark] .rsvp-event-details{background:#1a1a1a}[data-theme=dark] .rsvp-event-description{background:#2a2a2a}[data-theme=dark] .rsvp-detail-item{border-bottom-color:#444}@media (max-width: 768px){.rsvp-container{padding:60px 15px 15px}.rsvp-lang-toggle{top:15px;right:15px;padding:6px 12px;font-size:.85em}.rsvp-admin .page-title,.rsvp-page .page-title{font-size:2rem}.rsvp-admin .page-subtitle,.rsvp-page .page-subtitle{font-size:1.1rem}.rsvp-title-header{flex-direction:column;align-items:flex-start;gap:1rem}.rsvp-admin-header{flex-direction:column;align-items:stretch}.rsvp-admin-actions{justify-content:stretch}.rsvp-admin-actions button,.rsvp-admin-actions a{flex:1 1 auto;min-width:max-content}.rsvp-admin-stats{grid-template-columns:repeat(2,1fr)}.rsvp-form-row{grid-template-columns:1fr}.rsvp-form-actions{flex-direction:column}.rsvp-form-actions button,.rsvp-form-actions a{width:100%}.rsvp-admin-table{font-size:.85em}.rsvp-admin-table th,.rsvp-admin-table td{padding:6px}.rsvp-admin-events .rsvp-admin-table th:nth-child(5),.rsvp-admin-events .rsvp-admin-table td:nth-child(5),.rsvp-admin-events .rsvp-admin-table th:nth-child(6),.rsvp-admin-events .rsvp-admin-table td:nth-child(6),.rsvp-admin-events .rsvp-admin-table th:nth-child(7),.rsvp-admin-events .rsvp-admin-table td:nth-child(7){display:none}.rsvp-admin-table-container .rsvp-admin-table th:nth-child(4),.rsvp-admin-table-container .rsvp-admin-table td:nth-child(4),.rsvp-admin-table-container .rsvp-admin-table th:nth-child(5),.rsvp-admin-table-container .rsvp-admin-table td:nth-child(5){display:none}.rsvp-button{font-size:1em;padding:12px}.rsvp-button-sm{font-size:.85em;padding:10px 14px;max-width:none}.rsvp-collapsible-header{font-size:1em;padding:12px 16px}.rsvp-collapsible-header small{font-size:.8em}}@media (max-width: 480px){.rsvp-admin .page-title,.rsvp-page .page-title{font-size:1.5rem}.rsvp-admin-stats{grid-template-columns:1fr}.rsvp-stat-card{padding:16px}.rsvp-stat-number{font-size:1.75em}.rsvp-admin-table{font-size:.8em}.rsvp-admin-table th,.rsvp-admin-table td{padding:4px}.rsvp-admin-actions button,.rsvp-admin-actions a{font-size:.9em;padding:10px}.rsvp-buttons{flex-direction:column}.rsvp-button{width:100%}}.rte-container{border:1px solid var(--border);border-radius:.375rem;overflow:hidden}.rte-toolbar{display:flex;gap:4px;padding:8px;background:var(--bg-tertiary);border-bottom:1px solid var(--border);flex-wrap:wrap}.rte-toolbar button{padding:6px 10px;border:1px solid var(--border);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-size:14px;min-width:32px;transition:all .15s}.rte-toolbar button:hover{background:var(--bg-tertiary);border-color:var(--accent)}.rte-toolbar button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.rte-content{background:var(--bg-secondary)}.rte-content .tiptap{padding:12px;min-height:150px;outline:none;color:var(--text-primary)}.rte-content .tiptap p{margin:0 0 .5em}.rte-content .tiptap ul,.rte-content .tiptap ol{padding-left:1.5em;margin:.5em 0}.rte-content .tiptap a{color:var(--accent);text-decoration:underline}.rte-content .tiptap:focus{outline:none}.rte-content .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none;float:left;height:0}.footer{background:var(--bg-secondary);border-top:1px solid var(--border);padding:3rem 0 2rem;margin-top:4rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem;margin-bottom:3rem}.footer-title{font-size:1.125rem;margin-bottom:1rem;color:var(--text-primary)}.footer-text{color:var(--text-secondary);line-height:1.7}.footer-list{list-style:none;color:var(--text-secondary);line-height:1.8}.footer-links{display:flex;flex-direction:column;gap:.75rem}.footer-links a{color:var(--text-secondary);transition:color .2s ease}.footer-links a:hover{color:var(--accent)}.newsletter-form{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.newsletter-form input{padding:.75rem 1rem;font-size:.875rem;font-family:inherit;background:var(--bg-primary);border:1px solid var(--border);border-radius:.375rem;color:var(--text-primary);transition:border-color .2s ease}.newsletter-form input:focus{outline:none;border-color:var(--accent)}.newsletter-button{font-size:.875rem;padding:.75rem 1.5rem}.whitelist-instructions{margin-top:1rem}.whitelist-text{margin:0;color:var(--text-muted);font-size:.8125rem;line-height:1.5}.whitelist-text strong{color:var(--text-secondary);font-weight:600}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.875rem;position:relative}.version-indicator{position:absolute;bottom:.5rem;right:1rem;font-size:.625rem;color:var(--text-muted);opacity:.15;font-family:monospace;-webkit-user-select:none;user-select:none;transition:opacity .2s ease}.version-indicator:hover{opacity:.4}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;gap:2rem}}.app{min-height:100vh;display:flex;flex-direction:column}main{flex:1}#root{max-width:100%;margin:0;padding:0}
