:root{--color-text:#1a1a1a;--color-text-secondary:#6b6b6b;--color-text-tertiary:#999;--color-bg:#fff;--color-bg-secondary:#f5f5f5;--color-border:#e5e5e5;--color-border-hover:#ccc;--color-accent:#3b6d11;--color-accent-bg:#eaf3de;--max-width:680px}@media (prefers-color-scheme:dark){:root{--color-text:#e5e5e5;--color-text-secondary:#a0a0a0;--color-text-tertiary:#707070;--color-bg:#1a1a1a;--color-bg-secondary:#252525;--color-border:#333;--color-border-hover:#555;--color-accent:#7ab538;--color-accent-bg:#2a3d1a}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{color:var(--color-text);background:var(--color-bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5}.app-shell{max-width:var(--max-width);background:var(--color-bg);min-height:100dvh;margin:0 auto}.itinerary-info{margin-bottom:1rem}.route-steps{flex-direction:column;display:flex}.route-step{cursor:pointer;border-radius:8px;align-items:flex-start;gap:12px;padding:10px 8px;transition:background .15s;display:flex}.route-step:hover{background:var(--color-bg-secondary)}.route-step.selected{background:var(--color-accent-bg)}.route-step-marker{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.route-line{background:var(--color-border);width:2px;height:24px;margin-top:4px}.route-step-content{flex:1;min-width:0}.route-step-title{color:var(--color-text);font-size:14px;font-weight:500}.route-step-time{color:var(--color-accent);margin-top:2px;font-size:12px}.route-step-arrow{color:var(--color-text-tertiary);flex-shrink:0;margin-top:4px}.guide-footer{text-align:center;color:var(--color-text-tertiary);border-top:.5px solid var(--color-border);margin-top:2rem;padding-top:2rem;font-size:11px}button,a{align-items:center;min-height:44px;display:inline-flex}.tag,.hdr-pill,.leg-btn,.food-badge{min-height:auto}.panel{animation:.15s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@supports (padding:env(safe-area-inset-bottom)){.guide-page{padding-bottom:calc(2rem + env(safe-area-inset-bottom))}}.home-page{min-height:100dvh;padding:2rem 1rem}.home-header{text-align:center;margin-bottom:2rem}.home-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:#3b6d11;background:#eaf3de;border-radius:20px;align-items:center;gap:6px;margin-bottom:12px;padding:4px 12px;font-size:11px;font-weight:500;display:inline-flex}.home-header h1{letter-spacing:-.5px;color:var(--color-text);margin-bottom:6px;font-size:28px;font-weight:600}.home-subtitle{color:var(--color-text-secondary);font-size:14px}.city-list{flex-direction:column;gap:12px;max-width:500px;margin:0 auto;display:flex}.city-card{border:.5px solid var(--color-border);background:var(--color-bg);border-radius:12px;padding:20px 16px;text-decoration:none;transition:all .15s;display:block;position:relative}.city-card:hover{border-color:var(--color-border-hover);box-shadow:0 2px 8px #0000000a}.city-card-top h2{color:var(--color-text);margin-bottom:4px;font-size:20px;font-weight:600}.city-card-top p{color:var(--color-text-secondary);margin-bottom:12px;font-size:13px}.city-card-meta{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.city-card-stats{color:var(--color-text-tertiary);gap:16px;font-size:12px;display:flex}.city-card-arrow{color:var(--color-text-tertiary);position:absolute;top:50%;right:16px;transform:translateY(-50%)}.hdr{border-bottom:none;align-items:center;gap:8px;margin-bottom:0;padding:12px 0 10px;display:flex}.hdr-back{width:32px;height:32px;color:var(--color-text-secondary);min-height:unset;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;transition:background .15s;display:flex}.hdr-back:hover{background:var(--color-bg-secondary)}.hdr-center{flex:1;min-width:0}.hdr-name{color:var(--color-text);letter-spacing:-.3px;font-size:16px;font-weight:600;line-height:1.2}.hdr-region{color:var(--color-text-tertiary);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;overflow:hidden}.hdr-badge{letter-spacing:.06em;text-transform:uppercase;color:#3b6d11;background:#eaf3de;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:4px 8px;font-size:10px;font-weight:500;display:inline-flex}.hdr-avatar-wrap{border:2px solid #533ab7;border-radius:50%;flex-shrink:0;width:34px;height:34px;overflow:hidden;box-shadow:0 2px 8px #533ab733}.hdr-avatar{object-fit:cover;width:100%;height:100%}.tabs{scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:4px;margin-bottom:0;padding-bottom:2px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tb{border:.5px solid var(--color-border);background:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;border-radius:20px;flex-shrink:0;padding:7px 16px;font-family:inherit;font-size:13px;transition:all .15s}.tb:hover{background:var(--color-bg-secondary);color:var(--color-text)}.tb.on{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.gps-modal-backdrop{-webkit-backdrop-filter:blur(4px);z-index:100;background:#0009;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.gps-modal{background:var(--color-bg);border-radius:24px 24px 0 0;width:100%;padding:28px 24px 40px;animation:.3s cubic-bezier(.32,.72,0,1) slideUp}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@supports (padding:env(safe-area-inset-bottom)){.gps-modal{padding-bottom:calc(40px + env(safe-area-inset-bottom))}}.gps-modal-icon{margin-bottom:16px;font-size:40px;display:block}.gps-modal-title{color:var(--color-text);letter-spacing:-.3px;margin-bottom:10px;font-size:20px;font-weight:600}.gps-modal-body{color:var(--color-text-secondary);margin-bottom:16px;font-size:14px;line-height:1.65}.gps-modal-instruction{background:var(--color-bg-secondary);border-radius:12px;margin-bottom:20px;padding:12px 14px}.gps-modal-instruction-lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);margin-bottom:6px;font-size:10px;font-weight:600}.gps-modal-instruction p{color:var(--color-text);font-size:13px;line-height:1.55}.gps-modal-actions{flex-direction:column;gap:10px;display:flex}.gps-btn-primary{background:var(--color-text);width:100%;color:var(--color-bg);cursor:pointer;border:none;border-radius:12px;padding:14px;font-family:inherit;font-size:15px;font-weight:500;transition:opacity .15s}.gps-btn-primary:hover{opacity:.85}.gps-btn-secondary{width:100%;color:var(--color-text-secondary);border:.5px solid var(--color-border);cursor:pointer;background:0 0;border-radius:12px;padding:14px;font-family:inherit;font-size:14px;transition:background .15s}.gps-btn-secondary:hover{background:var(--color-bg-secondary)}.gps-btn-primary.gps-btn-loading{cursor:default;animation:1.4s ease-in-out infinite gps-btn-pulse}@keyframes gps-btn-pulse{0%,to{background:#374151}50%{background:#111827}}.gps-btn-spinner-wrap{justify-content:center;align-items:center;gap:10px;display:flex}.gps-btn-loading-label{letter-spacing:.01em}.gps-spinner{border:2.5px solid #ffffff4d;border-top-color:var(--color-bg);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite gps-spin;display:inline-block}@media (prefers-color-scheme:dark){.gps-spinner{border:2.5px solid #00000040;border-top-color:var(--color-bg)}}@keyframes gps-spin{to{transform:rotate(360deg)}}.gps-btn-secondary:disabled{opacity:.4;cursor:default}.pim-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:flex-end;animation:.2s both pim-fade-in;display:flex;position:fixed;inset:0}@keyframes pim-fade-in{0%{opacity:0}to{opacity:1}}.pim-sheet{background:var(--color-bg,#fff);border-radius:24px 24px 0 0;flex-direction:column;align-items:center;gap:0;width:100%;max-width:480px;padding:12px 24px 48px;animation:.35s cubic-bezier(.34,1.56,.64,1) both pim-slide-up;display:flex}@keyframes pim-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pim-handle{background:var(--color-border,#e5e7eb);border-radius:99px;flex-shrink:0;width:36px;height:4px;margin-bottom:20px}.pim-icon-wrap{margin-bottom:16px}.pim-diamond{background:#fff;border:2.5px solid #533ab7;border-radius:6px;justify-content:center;align-items:center;width:52px;height:52px;display:flex;transform:rotate(45deg);box-shadow:0 4px 16px #533ab733}.pim-diamond-inner{color:#533ab7;font-size:22px;font-weight:800;line-height:1;display:block;transform:rotate(-45deg)}.pim-title{color:var(--color-text,#111);text-align:center;letter-spacing:-.02em;margin:0 0 20px;font-size:20px;font-weight:800}.pim-body{flex-direction:column;gap:16px;width:100%;margin-bottom:24px;display:flex}.pim-block{background:var(--color-bg-secondary,#f9fafb);border-radius:14px;align-items:flex-start;gap:14px;padding:14px;display:flex}.pim-block-icon{flex-shrink:0;font-size:22px;line-height:1.2}.pim-block-title{color:var(--color-text,#111);margin-bottom:4px;font-size:14px;font-weight:700}.pim-block-text{color:var(--color-text-secondary,#6b7280);font-size:13px;line-height:1.5}.pim-btn-close{color:#fff;cursor:pointer;background:#533ab7;border:none;border-radius:14px;width:100%;padding:14px;font-family:inherit;font-size:15px;font-weight:600;transition:opacity .15s}.pim-btn-close:hover{opacity:.85}.map-container{border:.5px solid var(--color-border);border-radius:12px;margin-bottom:1rem;position:relative;overflow:hidden}.map-container--full{border:none;border-radius:0;width:100%;height:100%;margin-bottom:0}.map-canvas{width:100%;height:300px}.map-container--full .map-canvas{height:100%}.map-marker{color:#fff;cursor:pointer;border:2.5px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;transition:transform .15s;display:flex;box-shadow:0 2px 8px #0000004d}.map-marker:hover{transform:scale(1.2)}.map-marker-poi{cursor:pointer;background:#fff;border:2.5px solid;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;transition:transform .15s,box-shadow .15s;display:flex;transform:rotate(45deg);box-shadow:0 2px 8px #00000038}.map-marker-poi-emoji{font-size:13px;line-height:1;display:block;transform:rotate(-45deg)}.map-marker-poi:hover{transform:rotate(45deg)scale(1.2);box-shadow:0 4px 12px #0000004d}.user-dot{background:#4285f4;border:3px solid #fff;border-radius:50%;width:16px;height:16px;animation:2s ease-in-out infinite pulse;box-shadow:0 0 0 2px #4285f44d,0 2px 4px #0003}@keyframes pulse{0%,to{box-shadow:0 0 0 2px #4285f44d,0 2px 4px #0003}50%{box-shadow:0 0 0 10px #4285f414,0 2px 4px #0003}}.map-fab-group{z-index:25;flex-direction:column;gap:8px;display:flex;position:absolute;top:12px;right:12px}.map-container--full .map-fab-group{top:calc(var(--overlay-height,110px) + 12px);bottom:auto}.map-fab{background:var(--color-bg);border:.5px solid var(--color-border);cursor:pointer;width:44px;height:44px;color:var(--color-text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex;box-shadow:0 2px 8px #0000001f}.map-fab:hover{background:var(--color-bg-secondary)}.map-fab-poi-info{box-shadow:none;background:0 0;border:none;overflow:visible}.map-fab-poi-info:hover{opacity:.8;background:0 0}.map-fab-diamond{background:#fff;border:2.5px solid #533ab7;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex;transform:rotate(45deg);box-shadow:0 2px 8px #533ab740}.map-fab-diamond-inner{color:#533ab7;font-size:14px;font-weight:800;line-height:1;display:block;transform:rotate(-45deg)}.map-fab.active{color:#fff;background:#4285f4;border-color:#4285f4}.map-fallback{background:linear-gradient(160deg,#f0ebe0 0%,#e0d5c0 60%,#cfc6ad 100%);justify-content:center;align-items:center;width:100%;height:100%;min-height:250px;display:flex}.map-fallback-inner{text-align:center;padding:24px}.map-fallback-inner svg{opacity:.6;margin-bottom:12px}.map-fallback-title{color:var(--color-text);margin-bottom:6px;font-size:16px;font-weight:500}.map-fallback-subtitle{color:var(--color-text-secondary);margin-bottom:8px;font-size:12px}.map-fallback-subtitle code{background:#00000014;border-radius:3px;padding:1px 4px;font-size:11px}.map-fallback-code{color:var(--color-text);background:#0000001a;border-radius:6px;padding:5px 10px;font-family:monospace;font-size:11px;display:inline-block}.map-marker-peer{flex-direction:column;align-items:center;gap:3px;display:flex}.map-marker-peer-img{object-fit:cover;border:2.5px solid #533ab7;border-radius:50%;width:38px;height:38px;box-shadow:0 2px 8px #533ab759}.map-marker-peer-label{color:#fff;white-space:nowrap;background:#533ab7;border-radius:99px;padding:2px 6px;font-size:10px;font-weight:700;box-shadow:0 1px 4px #0003}.stop{border:.5px solid var(--color-border);background:var(--color-bg);cursor:pointer;border-radius:12px;margin-bottom:10px;transition:border-color .15s;overflow:hidden}.stop:hover{border-color:var(--color-border-hover)}.stop.open{border-color:var(--color-text-tertiary)}.stop-head{align-items:center;gap:12px;padding:14px;display:flex}.num{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:600;display:flex}.stop-info{flex:1;min-width:0}.stop-title{color:var(--color-text);margin-bottom:2px;font-size:15px;font-weight:500}.stop-cat{color:var(--color-text-secondary);font-size:12px}.stop-walk{color:var(--color-accent);font-weight:500}.chevron{color:var(--color-text-tertiary);flex-shrink:0;font-size:14px;transition:transform .2s}.stop.open .chevron{transform:rotate(180deg)}.stop-body{padding:0 14px 14px;display:none}.stop.open .stop-body{display:block}.tag-row{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.tag{letter-spacing:.04em;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:500}.stop-desc{color:var(--color-text-secondary);margin-bottom:12px;font-size:14px;line-height:1.65}.anecdote{background:var(--color-bg-secondary);border-left:2px solid #639922;border-radius:0 8px 8px 0;margin-bottom:12px;padding:10px 12px}.anecdote-lbl{text-transform:uppercase;letter-spacing:.08em;color:#3b6d11;margin-bottom:4px;font-size:10px;font-weight:500}.anecdote-txt{color:var(--color-text);font-size:13px;line-height:1.55}.legend-title{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;font-size:12px;font-weight:500}.obs-list{flex-direction:column;gap:6px;display:flex}.obs{color:var(--color-text-secondary);gap:8px;font-size:13px;line-height:1.45;display:flex}.obs-icon{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;margin-top:1px;display:flex}.stop-navigate{border:.5px solid var(--color-accent);background:var(--color-accent-bg);width:100%;color:var(--color-accent);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:6px;margin-top:12px;padding:10px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:flex}.stop-navigate:hover{background:var(--color-accent);color:#fff}.stop-detail{padding:0 14px 16px}.stop-detail-head{margin-bottom:10px}.stop-detail-back{color:var(--color-accent);cursor:pointer;min-height:unset;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-family:inherit;font-size:13px;display:inline-flex}.stop-detail-title-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.proximity-badge{color:#27500a;background:#eaf3de;border-radius:20px;align-items:center;gap:5px;margin-bottom:10px;padding:3px 9px;font-size:11px;font-weight:500;display:inline-flex}.proximity-dot{background:#639922;border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.timeline{padding-left:24px;position:relative}.timeline:before{content:"";background:var(--color-border);width:.5px;position:absolute;top:4px;bottom:4px;left:7px}.tl-item{margin-bottom:20px;position:relative}.tl-dot{border:2px solid var(--color-bg);border-radius:50%;flex-shrink:0;width:10px;height:10px;position:absolute;top:4px;left:-20px}.tl-year{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:3px;font-size:11px;font-weight:500}.tl-title{color:var(--color-text);margin-bottom:3px;font-size:14px;font-weight:500}.tl-desc{color:var(--color-text-secondary);font-size:13px;line-height:1.55}.sec-title{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin:1.5rem 0 .75rem;font-size:11px;font-weight:500}.sec-title:first-child{margin-top:0}.food-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1rem;display:grid}.food-card{background:var(--color-bg);border:.5px solid var(--color-border);border-radius:12px;padding:14px}.food-emoji{margin-bottom:8px;font-size:22px}.food-name{color:var(--color-text);margin-bottom:4px;font-size:14px;font-weight:500}.food-desc{color:var(--color-text-secondary);font-size:12px;line-height:1.5}.food-badge{color:#714906;text-transform:uppercase;letter-spacing:.04em;background:#faeeda;border-radius:20px;margin-top:6px;padding:2px 7px;font-size:10px;font-weight:500;display:inline-block}.tip-box{background:var(--color-bg-secondary);border-radius:8px;margin-bottom:10px;padding:12px 14px}.tip-box-lbl{text-transform:uppercase;letter-spacing:.07em;color:#3b6d11;margin-bottom:4px;font-size:10px;font-weight:500}.tip-box-txt{color:var(--color-text);font-size:13px;line-height:1.55}.score-header{background:var(--color-bg-secondary);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:12px 14px;display:flex}.score-lbl{color:var(--color-text-secondary);font-size:13px}.score-num{color:var(--color-text);font-size:22px;font-weight:500}.progress-bar{background:var(--color-border);border-radius:2px;min-width:120px;height:4px;margin-top:6px;overflow:hidden}.progress-fill{background:#639922;border-radius:2px;height:100%;transition:width .3s}.qcard{border:.5px solid var(--color-border);background:var(--color-bg);border-radius:12px;margin-bottom:12px;padding:16px}.q-num{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px;font-size:11px;font-weight:500}.q-txt{color:var(--color-text);margin-bottom:12px;font-size:15px;font-weight:500;line-height:1.5}.q-opts{flex-direction:column;gap:6px;display:flex}.opt{border:.5px solid var(--color-border);cursor:pointer;color:var(--color-text);background:var(--color-bg-secondary);text-align:left;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.4;transition:all .1s}.opt:hover:not(:disabled){border-color:var(--color-border-hover);background:var(--color-bg)}.opt.ok{color:#27500a;background:#eaf3de;border-color:#639922}.opt.ko{color:#501313;background:#fcebeb;border-color:#e24b4a}.opt:disabled{cursor:default}.q-expl{background:var(--color-bg-secondary);color:var(--color-text-secondary);border-radius:8px;margin-top:10px;padding:10px 12px;font-size:13px;line-height:1.55}.btn-reset{border:.5px solid var(--color-border);cursor:pointer;width:100%;color:var(--color-text-secondary);background:0 0;border-radius:8px;margin-top:1rem;padding:11px;font-family:inherit;font-size:13px}.btn-reset:hover{background:var(--color-bg-secondary)}.info-2col{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1rem;display:grid}.info-card{background:var(--color-bg);border:.5px solid var(--color-border);border-radius:12px;padding:14px}.info-lbl{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-size:11px}.info-val{color:var(--color-text);font-size:13px;line-height:1.5}.budget-table{border:.5px solid var(--color-border);border-radius:12px;margin-bottom:1rem;overflow:hidden}.budget-row{border-bottom:.5px solid var(--color-border);justify-content:space-between;padding:10px 14px;font-size:13px;display:flex}.budget-row:last-child{background:var(--color-bg-secondary);border-bottom:none;font-weight:500}.budget-label{color:var(--color-text-secondary)}.budget-cost{color:var(--color-text);font-weight:500}.vocab{border-top:.5px solid var(--color-border);margin-bottom:1rem}.vocab-row{border-bottom:.5px solid var(--color-border);justify-content:space-between;padding:9px 0;font-size:13px;display:flex}.v-it{color:var(--color-text);font-weight:500}.v-fr{color:var(--color-text-secondary);font-style:italic}.cs-root{background:var(--color-bg);flex-direction:column;gap:8px;min-height:100%;padding:20px 16px 0;display:flex}.cs-bg-area{margin:0 -16px;position:relative}.cs-bg-img{width:100%;height:auto;display:block}.cs-bg-content{position:absolute;inset:0}.cs-progress-wrap{flex-direction:column;gap:8px;display:flex}.cs-progress-bar{background:var(--color-border,#e5e7eb);border-radius:99px;height:6px;overflow:hidden}.cs-progress-fill{background:linear-gradient(90deg,#533ab7,#185fa5);border-radius:99px;height:100%;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.cs-progress-label{color:var(--color-text-secondary,#6b7280);align-items:baseline;gap:2px;font-size:13px;display:flex}.cs-progress-count{color:var(--color-text);font-size:20px;font-weight:700}.cs-cell{transform:translate(-50%, -50%) rotate(var(--stamp-rotate,0deg));position:absolute}.cs-cell--locked{opacity:.3;filter:grayscale()}.cs-stamp{background:0 0;border:3px solid;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:88px;height:88px;padding:6px;display:flex}.cs-cell--unlocked{animation:.4s cubic-bezier(.34,1.56,.64,1) both cs-stamp-in}@keyframes cs-stamp-in{0%{transform:translate(-50%, -50%) rotate(var(--stamp-rotate,0deg)) scale(.4);opacity:0}to{transform:translate(-50%, -50%) rotate(var(--stamp-rotate,0deg)) scale(1);opacity:1}}.cs-stamp--circle{border-radius:50%}.cs-stamp--hexagon{clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%)}.cs-stamp--shield{clip-path:polygon(0% 0%,100% 0%,100% 68%,50% 100%,0% 68%)}.cs-stamp--small{border-width:2px;width:58px;height:58px}.cs-stamp--small .cs-stamp-emoji{font-size:18px}.cs-stamp--small .cs-stamp-name,.cs-stamp--small .cs-stamp-date{font-size:6px}.cs-stamp--locked{color:#9ca3af;border:2px dashed #9ca3af;border-radius:12px;transform:none}.cs-stamp-emoji{font-size:26px;line-height:1}.cs-stamp-lock{font-size:20px}.cs-stamp-name{letter-spacing:.06em;text-transform:uppercase;color:currentColor;text-align:center;font-size:7.5px;font-weight:700;line-height:1.2}.cs-stamp-name--locked{color:#9ca3af;font-weight:600}.cs-stamp-date{color:currentColor;opacity:.6;font-size:7px;font-weight:500}.cs-bonus-list{flex-direction:column;gap:10px;padding-bottom:40px;display:flex}.cs-bonus-list-title{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary,#6b7280);margin-bottom:2px;font-size:11px;font-weight:700}.cs-bonus-card{border:1px solid var(--color-border,#e5e7eb);background:var(--color-bg-secondary,#f9fafb);border-radius:12px;overflow:hidden}.cs-bonus-header{border:none;border-left:4px solid var(--color-border,#e5e7eb);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:12px;width:100%;padding:14px;font-family:inherit;display:flex}.cs-bonus-icon{flex-shrink:0;font-size:22px}.cs-bonus-meta{flex:1;min-width:0}.cs-bonus-stop{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.cs-bonus-type{color:var(--color-text-secondary,#6b7280);margin-top:1px;font-size:11px}.cs-bonus-chevron{color:var(--color-text-secondary,#9ca3af);flex-shrink:0;transition:transform .25s}.cs-bonus-chevron--open{transform:rotate(180deg)}.cs-bonus-body{flex-direction:column;gap:12px;padding:0 14px 14px;animation:.25s both cs-expand;display:flex}@keyframes cs-expand{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.cs-bonus-secret{border-left:3px solid #533ab7;padding-left:10px}.cs-bonus-secret-label{letter-spacing:.1em;text-transform:uppercase;color:#533ab7;margin-bottom:5px;font-size:10px;font-weight:700}.cs-bonus-secret p{color:var(--color-text);margin:0;font-size:13px;line-height:1.55}.cs-bonus-content p{color:var(--color-text);white-space:pre-line;background:var(--color-bg,#fff);border-radius:8px;margin:0;padding:10px 12px;font-size:13px;line-height:1.7}.cs-empty{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:48px 24px;display:flex}.cs-empty-icon{font-size:48px}.cs-empty-title{color:var(--color-text);font-size:17px;font-weight:700}.cs-empty-text{color:var(--color-text-secondary,#6b7280);max-width:260px;margin:0;font-size:14px;line-height:1.6}.unlock-toast{z-index:120;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.unlock-backdrop{-webkit-backdrop-filter:blur(6px);background:#000000bf;animation:.3s forwards unlock-fade-in;position:absolute;inset:0}@keyframes unlock-fade-in{0%{opacity:0}to{opacity:1}}.unlock-center{z-index:1;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:360px;animation:.5s cubic-bezier(.34,1.56,.64,1) forwards unlock-slide-up;display:flex;position:relative}@keyframes unlock-slide-up{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.unlock-stamp-wrap{justify-content:center;align-items:center;animation:.5s cubic-bezier(.34,1.56,.64,1) .15s both stamp-press;display:flex;position:relative}@keyframes stamp-press{0%{opacity:0;transform:scale(2.2)}60%{transform:scale(.92)}to{opacity:1;transform:scale(1)}}.unlock-stamp{background:#ffffff14;border:4px solid;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:110px;height:110px;display:flex;position:relative}.unlock-stamp.stamp--circle{border-radius:50%}.unlock-stamp.stamp--hexagon{clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%)}.unlock-stamp.stamp--shield{clip-path:polygon(0% 0%,100% 0%,100% 68%,50% 100%,0% 68%)}.unlock-stamp-emoji{font-size:32px;line-height:1}.unlock-stamp-label{letter-spacing:.08em;text-transform:uppercase;color:currentColor;text-align:center;padding:0 4px;font-size:10px;font-weight:700}.unlock-stamp-city{letter-spacing:.15em;text-transform:uppercase;color:currentColor;opacity:.7;font-size:8px;font-weight:600}.unlock-stamp-date{color:currentColor;opacity:.6;font-size:8px;font-weight:500}.unlock-pulse-ring{pointer-events:none;border:3px solid;border-radius:50%;width:130px;height:130px;animation:.6s ease-out .4s both pulse-ring;position:absolute}@keyframes pulse-ring{0%{opacity:.8;transform:scale(.8)}to{opacity:0;transform:scale(1.6)}}.unlock-headline{color:#fff;letter-spacing:-.01em;font-size:22px;font-weight:700;animation:.5s cubic-bezier(.34,1.56,.64,1) .25s both unlock-slide-up}.unlock-content-card{-webkit-overflow-scrolling:touch;background:#ffffff1a;border:1px solid #ffffff2e;border-radius:16px;flex-direction:column;gap:14px;width:100%;max-height:40vh;padding:16px;animation:.5s cubic-bezier(.34,1.56,.64,1) .35s both unlock-slide-up;display:flex;overflow-y:auto}.unlock-secret{border-left:3px solid #ffffff80;padding-left:12px}.unlock-secret-label{letter-spacing:.1em;text-transform:uppercase;color:#fff9;margin-bottom:6px;font-size:10px;font-weight:700}.unlock-secret p{color:#ffffffe6;margin:0;font-size:13px;line-height:1.5}.unlock-bonus{background:#ffffff12;border-radius:10px;padding:12px}.unlock-bonus-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.unlock-bonus-emoji{font-size:18px}.unlock-bonus-title{color:#fff;font-size:13px;font-weight:700}.unlock-bonus-content{color:#fffc;white-space:pre-line;margin:0;font-size:12px;line-height:1.6}.unlock-dismiss-hint{color:#fff6;letter-spacing:.02em;font-size:12px;animation:.5s .5s both unlock-slide-up}.sm-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:flex-end;animation:.2s both sm-fade-in;display:flex;position:fixed;inset:0}@keyframes sm-fade-in{0%{opacity:0}to{opacity:1}}.sm-sheet{background:var(--color-bg,#fff);border-radius:24px 24px 0 0;flex-direction:column;width:100%;max-width:480px;height:80vh;animation:.35s cubic-bezier(.34,1.56,.64,1) both sm-slide-up;display:flex;overflow:hidden}@keyframes sm-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sm-handle{background:var(--color-border,#e5e7eb);border-radius:99px;flex-shrink:0;width:36px;height:4px;margin:12px auto 0}.sm-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px 8px;display:flex}.sm-title{color:var(--color-text,#111);font-size:18px;font-weight:700}.sm-close{color:var(--color-text-secondary,#6b7280);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:18px}.sm-search-wrap{background:var(--color-bg-secondary,#f3f4f6);border-radius:12px;flex-shrink:0;align-items:center;gap:10px;margin:8px 20px 12px;padding:10px 14px;display:flex}.sm-search-icon{font-size:15px}.sm-search{color:var(--color-text,#111);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:15px}.sm-search::placeholder{color:var(--color-text-secondary,#9ca3af)}.sm-list{flex:1;padding:0 20px 24px;overflow-y:auto}.sm-empty{text-align:center;color:var(--color-text-secondary,#6b7280);padding:40px 0;font-size:14px}.sm-user{border-bottom:1px solid var(--color-border,#f3f4f6);align-items:center;gap:12px;padding:10px 0;display:flex}.sm-avatar-wrap{border-radius:50%;flex-shrink:0;width:44px;height:44px;overflow:hidden}.sm-avatar{object-fit:cover;width:100%;height:100%}.sm-avatar-fallback{color:#fff;background:#533ab7;justify-content:center;align-items:center;width:100%;height:100%;font-size:18px;font-weight:700;display:flex}.sm-user-name{color:var(--color-text,#111);flex:1;font-size:15px;font-weight:500}.sm-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#533ab7;border:none;border-radius:20px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:opacity .15s}.sm-btn:hover{opacity:.85}.sm-btn--sent{background:var(--color-bg-secondary,#f3f4f6);color:var(--color-text-secondary,#6b7280);cursor:default}.sm-btn--stop{color:#dc2626;background:#fee2e2}.sm-btn--stop:hover{opacity:.85}.sm-active-section{flex-shrink:0;padding:0 20px 4px}.sm-section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary,#9ca3af);margin-bottom:4px;font-size:11px;font-weight:700}.sm-active-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 0 3px #22c55e33}.srt-toast{z-index:300;background:var(--color-bg,#fff);border-radius:18px;align-items:center;gap:12px;width:calc(100% - 32px);max-width:420px;padding:12px 16px;animation:.4s cubic-bezier(.34,1.56,.64,1) both srt-drop;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #0000002e}@keyframes srt-drop{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.srt-avatar-wrap{border:2px solid #533ab7;border-radius:50%;flex-shrink:0;width:44px;height:44px;overflow:hidden}.srt-avatar{object-fit:cover;width:100%;height:100%}.srt-avatar-fallback{color:#fff;background:#533ab7;justify-content:center;align-items:center;width:100%;height:100%;font-size:18px;font-weight:700;display:flex}.srt-content{flex:1;min-width:0}.srt-name{color:var(--color-text,#111);font-size:14px;font-weight:700}.srt-msg{color:var(--color-text-secondary,#6b7280);margin-top:2px;font-size:12px}.srt-actions{flex-shrink:0;gap:8px;display:flex}.srt-btn{cursor:pointer;box-sizing:border-box;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;min-width:36px;max-width:36px;height:36px;min-height:36px;max-height:36px;padding:0;font-size:15px;font-weight:700;line-height:1;transition:opacity .15s;display:flex;overflow:hidden}.srt-btn--refuse{color:#6b7280;background:#f3f4f6}.srt-btn--accept{color:#fff;background:#533ab7}.srt-btn:hover{opacity:.8}.guide-page{flex-direction:column;min-height:100dvh;display:flex}.guide-page.plan-mode{height:100dvh;overflow:hidden}.plan-view{width:100%;height:100dvh;position:relative}.plan-overlay-top{z-index:30;background:linear-gradient(to bottom, var(--color-bg) 70%, transparent);padding-bottom:8px;position:absolute;top:0;left:0;right:0}.plan-overlay-top .hdr,.plan-overlay-top .tabs{padding-left:1rem;padding-right:1rem}.bottom-sheet{background:var(--color-bg);max-height:var(--sheet-height,46%);z-index:20;border-radius:20px 20px 0 0;flex-direction:column;transition:transform .3s cubic-bezier(.32,.72,0,1),max-height .3s cubic-bezier(.32,.72,0,1);display:flex;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #0000001f}.bottom-sheet.collapsed{transform:translateY(calc(100% - 64px))}.sheet-handle-area{cursor:pointer;flex-shrink:0;justify-content:center;padding:10px 0 4px;display:flex}.sheet-handle{background:var(--color-border);border-radius:2px;width:36px;height:4px}.sheet-header{border-bottom:.5px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px 8px;display:flex}.sheet-title{color:var(--color-text);font-size:13px;font-weight:500}.sheet-duration{color:var(--color-accent);background:var(--color-accent-bg);border-radius:20px;flex-shrink:0;margin-left:8px;padding:3px 8px;font-size:12px;font-weight:500}.sheet-body{-webkit-overflow-scrolling:touch;flex:1;padding:4px 8px 16px;overflow-y:auto}@supports (padding:env(safe-area-inset-bottom)){.bottom-sheet{padding-bottom:env(safe-area-inset-bottom)}}.guide-content{flex:1;overflow-y:auto}.guide-topbar{background:var(--color-bg);z-index:10;padding:12px 1rem 0;position:sticky;top:0}.panel{padding:1rem 1rem 3rem;animation:.15s ease-out fadeIn}@supports (padding:env(safe-area-inset-bottom)){.panel{padding-bottom:calc(3rem + env(safe-area-inset-bottom))}}.share-location-btn{bottom:calc(var(--sheet-height) + 12px);z-index:50;color:#533ab7;cursor:pointer;background:#fff;border:2px solid #533ab7;border-radius:99px;align-items:center;gap:7px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s,color .15s;display:flex;position:absolute;left:16px;box-shadow:0 2px 12px #533ab733}.share-location-btn:hover{color:#fff;background:#533ab7}.ob-root{z-index:200;background:linear-gradient(160deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.ob-card{background:var(--color-bg);border-radius:28px 28px 0 0;flex-direction:column;width:100%;max-width:480px;min-height:60vh;padding:36px 24px 48px;animation:.5s cubic-bezier(.34,1.56,.64,1) both ob-slide-up;display:flex}@keyframes ob-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.ob-step{flex-direction:column;flex:1;align-items:center;gap:16px;animation:.3s both ob-fade-in;display:flex}@keyframes ob-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ob-emoji{font-size:52px;line-height:1}.ob-title{color:var(--color-text);text-align:center;letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700}.ob-subtitle{color:var(--color-text-secondary,#6b7280);text-align:center;margin:0;font-size:15px}.ob-input{border:2px solid var(--color-border,#e5e7eb);background:var(--color-bg-secondary,#f9fafb);width:100%;color:var(--color-text);text-align:center;box-sizing:border-box;border-radius:14px;outline:none;padding:14px 16px;font-family:inherit;font-size:17px;font-weight:500;transition:border-color .2s}.ob-input:focus{border-color:#533ab7}.ob-input--error{border-color:#ef4444}.ob-name-error{color:#ef4444;align-self:flex-start;margin:-8px 0 0;font-size:13px;font-weight:500}.ob-name-checking{color:var(--color-text-secondary,#9ca3af);align-self:flex-start;margin:-8px 0 0;font-size:13px}.ob-btn-primary{background:var(--color-text);width:100%;color:var(--color-bg);cursor:pointer;border:none;border-radius:14px;margin-top:auto;padding:15px;font-family:inherit;font-size:16px;font-weight:600;transition:opacity .15s}.ob-btn-primary:disabled{opacity:.3;cursor:default}.ob-btn-skip{color:var(--color-text-secondary,#9ca3af);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:8px;font-family:inherit;font-size:13px;text-decoration:underline}.ob-btn-secondary{background:var(--color-bg-secondary,#f3f4f6);color:var(--color-text);cursor:pointer;border:none;border-radius:12px;padding:13px 24px;font-family:inherit;font-size:15px;font-weight:500;transition:opacity .15s}.ob-camera-wrap{flex-shrink:0;width:220px;height:220px;position:relative}.ob-video{object-fit:cover;background:#000;border-radius:50%;width:220px;height:220px;transform:scaleX(-1)}.ob-camera-ring{pointer-events:none;border:3px solid #533ab7;border-radius:50%;animation:2s ease-in-out infinite ob-ring-pulse;position:absolute;inset:-6px}@keyframes ob-ring-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.03)}}.ob-btn-capture{cursor:pointer;background:#fff;border:3px solid #533ab7;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:68px;height:68px;transition:transform .1s;display:flex;box-shadow:0 4px 16px #533ab74d}.ob-btn-capture:active{transform:scale(.92)}.ob-btn-capture-inner{background:#533ab7;border-radius:50%;width:48px;height:48px;display:block}.ob-camera-error{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:24px;display:flex}.ob-camera-error-icon{font-size:40px}.ob-camera-error p{color:var(--color-text-secondary,#6b7280);margin:0;font-size:14px;line-height:1.5}.ob-avatar-wrap{border:4px solid #533ab7;border-radius:50%;flex-shrink:0;width:180px;height:180px;overflow:hidden;box-shadow:0 8px 32px #533ab740}.ob-avatar{object-fit:cover;width:100%;height:100%}.ob-preview-actions{gap:12px;width:100%;margin-top:auto;display:flex}.ob-preview-actions .ob-btn-primary{flex:1;margin-top:0}.pm-backdrop{z-index:150;-webkit-backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:flex-end;animation:.2s both pm-fade-in;display:flex;position:fixed;inset:0}@keyframes pm-fade-in{0%{opacity:0}to{opacity:1}}.pm-sheet{background:var(--color-bg);border-radius:24px 24px 0 0;flex-direction:column;align-items:center;width:100%;max-width:480px;padding:12px 24px 48px;animation:.35s cubic-bezier(.34,1.56,.64,1) both pm-slide-up;display:flex}@keyframes pm-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pm-handle{background:var(--color-border,#e5e7eb);border-radius:99px;flex-shrink:0;width:36px;height:4px;margin-bottom:24px}.pm-view{flex-direction:column;align-items:center;gap:16px;width:100%;animation:.25s both pm-view-in;display:flex}@keyframes pm-view-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pm-avatar-wrap{border:3px solid #533ab7;border-radius:50%;width:110px;height:110px;overflow:hidden;box-shadow:0 8px 28px #533ab738}.pm-avatar{object-fit:cover;width:100%;height:100%}.pm-name{color:var(--color-text);letter-spacing:-.02em;font-size:22px;font-weight:700}.pm-btn-change{color:#fff;cursor:pointer;background:#533ab7;border:none;border-radius:14px;width:100%;padding:14px;font-family:inherit;font-size:15px;font-weight:600;transition:opacity .15s}.pm-btn-change:hover{opacity:.85}.pm-btn-close{background:var(--color-bg-secondary,#f3f4f6);width:100%;color:var(--color-text);cursor:pointer;border:none;border-radius:14px;padding:13px;font-family:inherit;font-size:15px;font-weight:500}.pm-btn-admin{color:#fff;cursor:pointer;background:#1e1b4b;border:none;border-radius:14px;width:100%;margin-bottom:8px;padding:13px;font-family:inherit;font-size:15px;font-weight:500}.pm-btn-admin:hover{opacity:.85}.pm-camera-title{color:var(--color-text);font-size:18px;font-weight:700}.pm-camera-wrap{width:200px;height:200px;position:relative}.pm-video{object-fit:cover;background:#000;border-radius:50%;width:200px;height:200px;transform:scaleX(-1)}.pm-camera-ring{pointer-events:none;border:3px solid #533ab7;border-radius:50%;animation:2s ease-in-out infinite pm-ring-pulse;position:absolute;inset:-5px}@keyframes pm-ring-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.03)}}.pm-btn-capture{cursor:pointer;background:#fff;border:3px solid #533ab7;border-radius:50%;justify-content:center;align-items:center;width:62px;height:62px;transition:transform .1s;display:flex;box-shadow:0 4px 14px #533ab747}.pm-btn-capture:active{transform:scale(.92)}.pm-btn-capture-inner{background:#533ab7;border-radius:50%;width:44px;height:44px;display:block}.pm-camera-error{flex-direction:column;align-items:center;gap:12px;display:flex}.pm-camera-error p{color:var(--color-text-secondary,#6b7280);margin:0;font-size:14px}.pm-preview-actions{gap:10px;width:100%;display:flex}.pm-preview-actions .pm-btn-close,.pm-preview-actions .pm-btn-change{flex:1}.ap-pin-screen{flex-direction:column;align-items:center;gap:12px;padding:36px 24px 40px;display:flex}.ap-pin-icon{font-size:2.5rem}.ap-pin-sub{color:var(--color-text-secondary);text-align:center;margin:0;font-size:.9rem}.ap-pin-input{border:2px solid var(--color-border);text-align:center;letter-spacing:4px;background:var(--color-bg);width:100%;color:var(--color-text);box-sizing:border-box;border-radius:14px;outline:none;padding:14px 16px;font-family:inherit;font-size:1.1rem}.ap-pin-input--error{border-color:#ef4444}.ap-pin-input:focus{border-color:#533ab7}.ap-pin-error{color:#ef4444;margin:0;font-size:.85rem}.ap-pin-btn{color:#fff;cursor:pointer;background:#533ab7;border:none;border-radius:14px;width:100%;padding:14px;font-family:inherit;font-size:1rem;font-weight:600}.ap-pin-btn:disabled{opacity:.5;cursor:not-allowed}.ap-pin-cancel{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.9rem}.ap-overlay{z-index:300;background:#00000080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.ap-sheet{background:var(--color-bg);border-radius:20px 20px 0 0;flex-direction:column;width:100%;max-width:480px;max-height:85vh;animation:.25s ease-out ap-slide-up;display:flex}@keyframes ap-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ap-header{justify-content:space-between;align-items:center;padding:20px 20px 0;display:flex}.ap-title{margin:0;font-size:1.1rem;font-weight:700}.ap-close{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1.1rem}.ap-count{color:var(--color-text-secondary);padding:6px 20px 12px;font-size:.8rem}.ap-loading{text-align:center;color:var(--color-text-secondary);padding:40px}.ap-list{flex:1;margin:0;padding:0 12px 32px;list-style:none;overflow-y:auto}.ap-item{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;padding:10px 8px;display:flex}.ap-item:last-child{border-bottom:none}.ap-avatar{object-fit:cover;background:#eee;border-radius:50%;flex-shrink:0;width:40px;height:40px}.ap-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.ap-name{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.ap-date{color:var(--color-text-secondary);font-size:.75rem}.ap-delete{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:6px;font-size:1.1rem;transition:background .15s}.ap-delete:hover{background:#fee2e2}.ap-delete:disabled{opacity:.4;cursor:not-allowed}
