:root{line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}:root{font-family:Space Grotesk,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#0f172a}body{background:linear-gradient(135deg,#0f172a,#1d2955);margin:0;min-height:100vh;overflow:hidden}#root{min-height:100vh}.app-shell{margin:0 auto;max-width:540px;padding:1.5rem;display:flex;flex-direction:column;min-height:100vh;color:#f8fafc;position:relative}.app-content{flex:1;display:flex;flex-direction:column;gap:1rem;min-height:100%;transition:opacity .5s ease,filter .5s ease}.app-content.initial{opacity:0;filter:blur(6px)}.splash-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 20%,#1e40af80,#0f172af2);z-index:200;opacity:1;transition:opacity .6s ease,transform .6s ease}.splash-screen.fade-out{opacity:0;transform:translateY(-20px)}.splash-card{max-width:520px;width:100%;background:linear-gradient(160deg,#0f172af2,#0f172ad9);border-radius:1.75rem;padding:2.6rem 1.6rem!important;border:1px solid rgba(59,130,246,.45);box-shadow:0 45px 120px -45px #0ea5e9d9,0 0 40px -20px #3b82f699 inset}.hero{text-align:center;padding:0}.hero h1{font-size:2.1rem;margin:.1rem 0 .15rem}.eyebrow{text-transform:uppercase;font-size:.75rem;letter-spacing:.3em;color:#38bdf8;margin:0}.muted{color:#94a3b8;margin:.15rem 0}.tiny{font-size:.78rem;margin-top:.2rem;color:#cbd5f5}.card{background:#0f172aeb;border-radius:1.25rem;padding:1.25rem;box-shadow:0 25px 65px -25px #0f172acc;border:1px solid rgba(37,99,235,.25);color:#f1f5f9}.modal-overlay{position:fixed;inset:0;background:#0f172aa6;display:flex;justify-content:center;align-items:flex-start;padding:1rem;overflow-y:auto;z-index:100}.modal-card{width:100%;max-width:520px;margin-top:1rem}.card.centered{text-align:center}.stacked{display:flex;flex-direction:column;gap:1rem;flex:1;overflow:hidden}.card-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.device-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;flex-wrap:wrap}.device-meta{display:flex;flex-direction:column;gap:.2rem}.device-name-button{background:transparent;border:none;padding:0;font-size:1.3rem;font-weight:600;color:#f8fafc;cursor:pointer;text-align:left}.device-name-button:hover{text-decoration:underline}.device-guid{font-size:.78rem;color:#94a3b8;word-break:break-all;margin-top:0}.subtle-guid{margin-top:.5rem;font-size:.7rem;opacity:.7;text-align:right}.device-action-column{display:flex;flex-direction:column;gap:.4rem;align-items:flex-end}.ghost.interest-button{background:linear-gradient(135deg,#2563eb,#7c3aed);border:none;color:#fff;padding:.45rem 1.2rem;font-weight:600;box-shadow:0 10px 20px -12px #2563ebb3}.ghost.reset-button{font-size:.8rem;padding:.15rem .8rem;background:#fbbf2426;border-color:#fbbf2459;color:#92400e;font-weight:600;border-width:1px}.interest-button{align-self:flex-end;font-weight:600}.device-card{flex-shrink:0}.interest-summary-card{display:flex;flex-direction:column;gap:.75rem;border-radius:1rem;border:1px solid rgba(148,163,184,.35);padding:1rem;background:#0f172a99}.interest-summary-card .interest-button{align-self:flex-start}.interest-count{font-weight:600;color:#e2e8f0;margin-top:.4rem}.interest-summary-list{display:flex;flex-wrap:wrap;gap:.4rem;margin:.35rem 0 0}.interest-summary-list span{border-radius:999px;padding:.3rem .75rem;background:#3b82f626;color:#bfdbfe;font-size:.85rem;border:1px solid rgba(59,130,246,.3)}.stacked-form{display:flex;flex-direction:column;gap:1rem}label{display:flex;flex-direction:column;gap:.4rem;font-weight:600;color:#e2e8f0}input,select,textarea{border-radius:.75rem;border:1px solid rgba(148,197,255,.35);padding:.75rem;font-size:1rem;font-family:inherit;background:#0f172ad9;color:#f8fafc}textarea{resize:vertical}.interest-selector-tree{margin-top:.5rem;max-height:320px;overflow-y:auto;padding-right:.5rem;scroll-behavior:smooth}.interest-tree{list-style:none;padding-left:0;margin:0;display:flex;flex-direction:column;gap:.3rem}.interest-branch{display:flex;flex-direction:column;gap:.25rem}.interest-node-row{display:flex;align-items:center;gap:.4rem}.interest-toggle{border:1px solid rgba(76,110,245,.45);background:#0f172ad9;border-radius:.4rem;width:1.6rem;height:1.6rem;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#f8fafc}.interest-toggle.placeholder{visibility:hidden}.interest-chip{flex:1;border-radius:1rem;border:1px solid rgba(76,110,245,.35);background:#0e182ce6;padding:.55rem .9rem;text-align:left;font-size:.95rem;color:#e2e8f0}.interest-chip.active{border-color:transparent;background:linear-gradient(120deg,#2563eb,#7c3aed);color:#f8fafc;box-shadow:0 12px 20px -14px #3b82f6cc;font-weight:600}.interest-chip small{display:block;color:#c7d2fe;font-weight:500;margin-top:.15rem}.primary{background:linear-gradient(135deg,#4ade80,#2dd4bf);border:none;color:#0f172a;font-weight:700;border-radius:999px;padding:.85rem 1.5rem;cursor:pointer}.ping-button{position:relative;overflow:visible;z-index:1;display:inline-flex;align-items:center;justify-content:center}.ping-button:after,.ping-button:before{content:"";position:absolute;inset:-.3rem;border-radius:999px;pointer-events:none;opacity:0;z-index:0}.ping-button.pulsing:after{background:radial-gradient(circle,rgba(148,197,255,.6) 0%,transparent 70%);animation:pingPulse 2.4s ease-out forwards}.ping-button.pulsing:before{border:2px solid rgba(148,197,255,.4);animation:pingPulseRing 2.4s ease-out forwards}@keyframes pingPulse{0%{transform:scale(1);opacity:.6}to{transform:scale(2.3);opacity:0}}@keyframes pingPulseRing{0%{transform:scale(1);opacity:.7}to{transform:scale(2.6);opacity:0}}.ping-button-label{display:inline-block}button{font-family:inherit}button:disabled{opacity:.6;cursor:not-allowed}.ghost{background:#94a3b82e;border:1px solid rgba(148,163,184,.4);border-radius:999px;padding:.65rem 1.25rem;color:#e2e8f0;cursor:pointer}.grid{display:grid;gap:.75rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.slider{color:#cbd5ff;font-weight:600}.slider input[type=range]{width:100%}.location-readout{display:flex;justify-content:space-between;gap:1rem;margin-bottom:.5rem;font-size:.85rem}.location-readout .muted{font-size:.65rem}.location-readout .mono{font-size:.8rem;margin:.05rem 0 0}.actions{display:flex;gap:.75rem;justify-content:center}.interest-editor .actions{justify-content:flex-end}.status-line{margin-top:.5rem;display:flex;align-items:center;gap:.25rem}.status-line:before{content:"";width:1.05rem;display:inline-block}.status-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.last-ping-label{margin-top:.5rem;font-size:.75rem;color:#94a3b8}.status-line.matches:before{content:"🔥"}.status-line.error{color:#dc2626}.match-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.collisions-card{flex:0 1 auto;display:flex;flex-direction:column;overflow:hidden;min-height:280px;max-height:calc(100vh - 220px)}.collisions-card header{display:flex;flex-direction:column;gap:.2rem}.collisions-card header .muted{margin:0}.match-list-scroll{flex:1;overflow-y:auto;padding-right:.25rem;margin-top:1rem;min-height:0;max-height:clamp(220px,calc(100vh - 420px),420px)}.match-card{border-radius:1.1rem;border:1px solid rgba(59,130,246,.35);padding:1rem;background:linear-gradient(150deg,#0f172afa,#1e293bd9);display:flex;justify-content:space-between;align-items:center;gap:.75rem;box-shadow:0 18px 35px -25px #0f172ae6;width:100%;text-align:left;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.match-button{width:100%;border:none;background:transparent;padding:0;color:inherit;cursor:pointer;text-align:left}.match-button:hover,.match-button:focus-visible{transform:translateY(-2px);border-color:#3b82f68c;box-shadow:0 25px 45px -25px #0ea5e980}.match-button:focus-visible{outline:2px solid rgba(59,130,246,.7);outline-offset:6px;border-radius:1.2rem}.match-name{font-size:1.05rem;margin:0 0 .2rem}.error-message{background:#f8717133;border-radius:.75rem;padding:.65rem;color:#7f1d1d;font-weight:600}.empty-state{text-align:center;padding:1rem 0;color:#475569}.registration-card header{text-align:center}.interest-form-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;flex-wrap:wrap}.match-detail-body{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.match-detail-modal .interest-summary-list{margin-top:0}.mono{font-family:JetBrains Mono,Space Mono,monospace;word-break:break-all}@media(max-height:1080px){.collisions-card{max-height:calc(100vh - 200px)}.match-list-scroll{max-height:clamp(200px,calc(100vh - 360px),360px)}}@media(max-height:896px){.collisions-card{max-height:calc(100vh - 170px)}.match-list-scroll{max-height:clamp(180px,calc(100vh - 320px),320px)}}@media(max-height:780px){.collisions-card{max-height:calc(100vh - 150px)}.match-list-scroll{max-height:clamp(160px,calc(100vh - 300px),280px)}}
