.modal { position:fixed;inset:0;display:flex;justify-content:center;align-items:flex-start;padding-top:3rem;background:#0009;backdrop-filter:blur(4px);z-index:10000;visibility:hidden;opacity:0;transform:scale(0.98);transition:opacity .25s ease, transform .25s ease, visibility 0s linear .25s;} .modal.visible { visibility:visible;opacity:1;transform:scale(1);transition:opacity .25s ease, transform .25s ease, visibility 0s;} body.modal-open { overflow:hidden;position:fixed;width:100%;padding-right:var(--scrollbar-width, 0);} .modal-content { position:relative;background:var(--card);color:var(--fg);width:92%;max-width:26rem;padding:1.1rem 1.2rem;border-radius:0.75rem;box-shadow:0 4px 24px rgba(0,0,0,0.28);margin-bottom:5rem;animation:modalSlide .25s ease-out;} @keyframes modalSlide { from { opacity:0;transform:translateY(-12px) scale(.98);} to { opacity:1;transform:translateY(0) scale(1);} } .modal-close { position:absolute;top:.25rem;right:.4rem;background:none;border:none;font-size:1.4rem;color:var(--muted);cursor:pointer;transition:color .25s ease, transform .1s ease;} .modal-close:hover { color:var(--accent);transform:scale(1.1);} body.night .modal-content { background:#2b2418;color:#f6eedd;box-shadow:0 0 15px #f0dca040, 0 0 40px #000000b3 inset;} body.night .modal-close { color:#ccbfa9;} .modal .menu-search { display:flex;align-items:center;gap:1rem;width:100%;margin:0.2rem 0 1.2rem;padding:1rem 1.1rem;background:#ffffffd1;border:1px solid #d3c0a4;border-radius:.9rem;backdrop-filter:blur(6px);box-shadow:0 3px 12px #0000001a, inset 0 1px 2px #fff6;position:relative;} .modal .menu-search::before { content:"";position:absolute;inset:0;border-radius:inherit;background:url(/assets/img/paper-texture.jpg) center/cover no-repeat;opacity:.12;mix-blend-mode:multiply;pointer-events:none;z-index:0;} .modal .menu-search .search-input-wrapper { flex:1;position:relative;z-index:1;} .modal .menu-search input[type=search] { width:100%;padding:.9rem 1rem;font-size:1.05rem;background:#fffdfa;border:1px solid #c5b299;border-radius:.6rem;transition:border-color .2s, box-shadow .2s;} .modal .menu-search input[type=search]:focus { border-color:#b48c5a;outline:none;box-shadow:0 0 0 3px #b48c5a40;} .modal .menu-search button { padding:.9rem 1.4rem;font-size:1rem;font-weight:600;background:#f7efe4;border:1px solid #b48c5a;border-radius:.6rem;color:#5a4837;cursor:pointer;transition:background .2s, transform .2s;z-index:1;} .modal .menu-search button:hover { background:#ffefd9;transform:translateY(-2px);} .modal .live-results { position:absolute;top:100%;left:0;right:0;max-height:55vh;overflow-y:auto;background:var(--bg);border:1px solid #d3c0a4;border-top:none;border-radius:0 0 .6rem .6rem;padding:.3rem 0;box-shadow:0 6px 18px rgba(0,0,0,.17);z-index:9999;} body.night .modal .menu-search { background:#201a12eb;border-color:#403223;box-shadow:0 2px 12px #000a, inset 0 1px 2px #ffe6b414;} body.night .modal .menu-search input[type=search] { background:#1e180f;border-color:#6a5338;color:#f6eedd;} body.night .modal .menu-search input[type=search]:focus { border-color:#d6b874;box-shadow:0 0 0 3px #d6b87440;} body.night .modal .menu-search button { background:#d6b874;color:#2b1c0a;border-color:#c6a564;} body.night .modal .menu-search button:hover { background:#e9cf93;} body.night .modal .live-results { background:#1e180f;border-color:#6a5338;box-shadow:0 6px 16px #000000c0;} .modal .menu-categories { list-style:none;margin:0.25rem 0 0.75rem;padding:0;} .modal .menu-categories li { margin:0.2rem 0;} .modal .menu-categories a { display:block;padding:0.55rem 0.3rem;border-radius:0.4rem;text-decoration:none;color:var(--fg);font-size:1.05rem;line-height:1.3;transition:background .2s ease, color .2s ease;} .modal .menu-categories a:hover { background:#f6efe6;} .modal .menu-categories a.is-current { font-weight:600;color:var(--accent);} body.night .modal .menu-categories a:hover { background:#3a2e22;} body.night .modal .menu-categories a.is-current { color:#ffe6a3;} @media (max-width:600px) { .modal { padding-top:0.6rem;} .modal-content { width:95%;padding:1rem 1rem;border-radius:.75rem;animation:modalSlideMobile .22s ease-out;} @keyframes modalSlideMobile { from { opacity:0;transform:translateY(-16px);} to { opacity:1;transform:translateY(0);} } }