: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)}.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}}.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)}[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}}.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}@keyframes spin{to{transform:rotate(360deg)}}.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}.back-link{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:2rem;color:var(--text-secondary);transition:color .2s ease;text-decoration:none}.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}.back-link:hover{color:var(--accent)}.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}.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}}.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}
