:root{--app-height: 100vh}html,body,#app{margin:0;padding:0;font-family:Roboto,sans-serif;background-color:#f5f5f5;color:#333;font-size:16px;line-height:1.5;width:100%;height:var(--app-height);min-height:var(--app-height);position:relative;overflow:hidden;overscroll-behavior:none}.modal-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:stretch;justify-content:stretch}.modal-content{background:#fff;position:relative;cursor:default}.modal-panel{padding:2em 1.5em;background:#f7f7f7;display:flex;flex-direction:column;justify-content:start}.modal-close{position:absolute;background:none;border:none;cursor:pointer;z-index:10001}.nav-buttons{position:absolute;display:flex;flex-direction:column;gap:12px;z-index:10000}.nav-left{left:24px}.nav-right{right:24px}.nav-button{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fffffff2;border:2px solid #333;border-radius:8px;font-size:1rem;font-weight:600;color:#333;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #00000026}.nav-button:hover{background:#333;color:#fff;transform:scale(1.05);box-shadow:0 6px 20px #00000040}.nav-button .arrow{font-size:1.5em;font-weight:700;line-height:1}.nav-button .label{white-space:nowrap}.modal-fade-enter-active,.modal-fade-leave-active{transition:opacity .4s cubic-bezier(.4,0,.2,1)}.modal-fade-enter-from,.modal-fade-leave-to{opacity:0}.cuadro-modal-overlay{background:#000000eb}.cuadro-modal-content{display:flex;flex-direction:column;width:100vw;height:var(--app-height);border-radius:0;overflow:hidden;box-shadow:none;animation:modal-in .4s cubic-bezier(.4,0,.2,1);position:relative}.cuadro-modal-image{flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center;background:#222}.cuadro-modal-image img{max-height:100%;max-width:100%;width:auto;height:auto;object-fit:contain;border-radius:0;transition:transform .4s cubic-bezier(.4,0,.2,1)}.cuadro-modal-panel{flex:0 0 10vh;height:fit-content;min-height:10vh;padding:1rem;box-shadow:none;overflow-y:auto;background:#f7f7f7;margin-top:20px}.cuadro-modal-close{top:12px;right:12px;font-size:1.6rem;color:#fff;mix-blend-mode:difference}.cuadro-nav-buttons{top:auto;bottom:8vh;transform:none}.cuadro-modal-footer{display:none}@media(max-width:1023px){.cuadro-modal-content{display:grid;grid-template-rows:minmax(0,1fr) auto;height:var(--app-height);padding-bottom:0}.cuadro-modal-panel{display:none}.cuadro-modal-image{flex:none;grid-row:1;min-height:0}.nav-left,.nav-right{display:none}.cuadro-modal-footer{display:grid;position:relative;grid-row:2;left:0;right:0;bottom:auto;height:auto;min-height:60px;max-height:min(calc(var(--app-height) * .34),240px);grid-template-columns:44px 1fr 44px;gap:6px;align-items:center;padding:6px 8px calc(6px + env(safe-area-inset-bottom));background:linear-gradient(to top,#000000eb,#000000bf);border-top:1px solid rgba(255,255,255,.08);z-index:10010;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cuadro-modal-footer .footer-prev,.cuadro-modal-footer .footer-next{display:flex;align-items:center;justify-content:center}.cuadro-modal-footer .nav-button{padding:0;width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#fffffff2;border:2px solid #333;box-shadow:0 4px 12px #0003;transition:all .2s ease}.cuadro-modal-footer .nav-button:active{transform:scale(.95);background:#ffffffd9}.cuadro-modal-footer .nav-button .label{display:none}.cuadro-modal-footer .nav-button .arrow{font-size:1.4em;font-weight:700}.cuadro-modal-footer .footer-center{overflow:hidden;display:flex;align-items:stretch;min-height:0;max-height:100%}.cuadro-modal-footer .footer-content{color:#fff;width:100%;max-height:calc(min(calc(var(--app-height) * .34),240px) - 12px - env(safe-area-inset-bottom));overflow-y:auto;overflow-x:hidden;padding:4px 8px;display:flex;flex-direction:column;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent;flex-shrink:1}.cuadro-modal-footer .footer-content::-webkit-scrollbar{width:4px}.cuadro-modal-footer .footer-content::-webkit-scrollbar-track{background:transparent}.cuadro-modal-footer .footer-content::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.cuadro-modal-footer .footer-title{margin:0 0 4px;font-size:.95rem;font-weight:700;line-height:1.2;color:#fff;flex-shrink:0}.cuadro-modal-footer .footer-desc{font-size:.82rem;line-height:1.3;color:#ffffffe6;flex:1;overflow-y:auto}}@media(min-width:768px)and (max-width:1023px){.cuadro-modal-footer{min-height:70px;max-height:min(calc(var(--app-height) * .36),300px);padding:10px 12px}.cuadro-modal-footer .footer-title{font-size:1rem}.cuadro-modal-footer .footer-desc{font-size:.88rem}.cuadro-modal-footer .nav-button{width:48px;height:48px}}@media(min-width:1024px){.cuadro-modal-content{flex-direction:row;align-items:stretch;overflow:hidden;padding-bottom:0}.cuadro-modal-image{flex:1 1 auto;height:var(--app-height);width:100%}.cuadro-modal-image img{max-height:100%;max-width:100%;width:auto;height:auto;object-fit:contain}.cuadro-modal-panel{display:flex;position:absolute;top:20px;right:20px;width:320px;max-width:calc(100vw - 40px);max-height:calc(var(--app-height) - 80px);padding:1.25rem 1rem;background:#fffffff5;box-shadow:0 8px 32px #0000002e;overflow-y:auto;border-radius:12px;z-index:10002;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cuadro-modal-panel h2{margin-top:0;margin-bottom:.75rem;font-size:1.25rem;line-height:1.3;color:#222}.cuadro-modal-panel p{margin:0;font-size:.95rem;line-height:1.5;color:#555}.cuadro-modal-footer{display:none}}.cartel-modal-overlay{background:#0003;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px)}.cartel-modal-content{margin:auto;max-width:800px;max-height:90vh;overflow-y:auto;border-radius:8px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column}.cartel-modal-panel{padding:20px 20px 90px;flex:1}.cartel-modal-panel h2{margin-top:0;color:#333}.cartel-modal-panel p,.cartel-modal-panel div{color:#666;line-height:1.6}.cartel-modal-close{top:10px;right:10px;font-size:24px;color:#fff;mix-blend-mode:difference;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.cartel-modal-close:hover{background:#0000001a}.cartel-nav-buttons{bottom:20px;flex-direction:row;gap:10px}.cartel-nav-right{right:20px}@keyframes modal-in{0%{transform:scale(.98);opacity:0}to{transform:scale(1);opacity:1}}
