/* #SECTION: PROFILE */
/* ═══════ PROFILE ═══════ */

.trainer-card{background:linear-gradient(135deg,#ef4444 0%,#b91c1c 40%,#1e293b 40%,#1e293b 100%);border-radius:18px;padding:2rem;color:#fff;position:relative;overflow:hidden;min-height:200px;box-shadow:var(--shadow-lg)}
.trainer-card .tc-wm{position:absolute;right:-20px;bottom:-20px;opacity:.06;pointer-events:none}
.trainer-card .tc-top{display:flex;align-items:center;gap:1.2rem}
.tc-avatar{width:72px;height:72px;border-radius:16px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:2rem;border:3px solid rgba(255,255,255,.2);cursor:pointer;position:relative;overflow:hidden;transition:all .2s}
.tc-avatar:hover{border-color:rgba(255,255,255,.5)}
.tc-avatar img{width:100%;height:100%;object-fit:cover}
.tc-avatar .av-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:#fff}
.tc-avatar:hover .av-overlay{display:flex}
.tc-info h2{font-size:1.3rem;font-weight:800}.tc-info .tc-email{font-size:.78rem;opacity:.65;margin-top:2px}
.tc-info .tc-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;opacity:.5;margin-top:.4rem}
.tc-stats{display:flex;gap:1.5rem;margin-top:1.2rem}
.tc-stat .tc-sv{font-size:1.6rem;font-weight:800}.tc-stat .tc-sl{font-size:.62rem;text-transform:uppercase;letter-spacing:.05em;opacity:.6}
.name-edit{display:flex;gap:.4rem;align-items:center;margin-top:.6rem}
.name-edit input{padding:.35rem .6rem;border-radius:7px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;font-family:inherit;font-size:.85rem;font-weight:600;width:200px}
.name-edit input::placeholder{color:rgba(255,255,255,.4)}
.name-edit button{padding:.35rem .6rem;border-radius:7px;border:none;background:rgba(255,255,255,.2);color:#fff;font-family:inherit;font-weight:600;font-size:.75rem;cursor:pointer}
.name-edit button:hover{background:rgba(255,255,255,.3)}

.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.8rem;margin-top:1rem}
.ach-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:.9rem;display:flex;gap:.8rem;align-items:flex-start;transition:all .2s}
.ach-card.unlocked{border-color:var(--gold);background:var(--gold-bg)}
.ach-card.locked{opacity:.4;filter:grayscale(40%)}
.ach-icon{font-size:1.8rem;flex-shrink:0;width:40px;text-align:center}
.ach-info .ach-name{font-weight:700;font-size:.85rem}
.ach-info .ach-desc{font-size:.72rem;color:var(--muted);margin-top:2px;line-height:1.3}
.ach-info .ach-date{font-size:.62rem;color:var(--gold);margin-top:4px;font-weight:600}
.ach-info .ach-cat{font-size:.58rem;color:var(--muted2);text-transform:uppercase;letter-spacing:.05em;margin-top:3px}
/* Drop I.1: achievement category header + progress bar */
.ach-cat-hdr{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:0}
.ach-card.unlocked{border-width:1.5px}
.ach-prog{margin-top:5px;display:flex;align-items:center;gap:.45rem}
.ach-prog-bar-track{flex:1;height:4px;background:var(--surface2);border-radius:2px;overflow:hidden}
.ach-prog-bar{height:100%;border-radius:2px;transition:width .3s}
.ach-prog-txt{font-size:.6rem;color:var(--muted);font-weight:700;white-space:nowrap;flex-shrink:0}

/* ── Drop I.2: Friends system ── */
.fr-collapse{border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:.3rem 0}
.fr-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s;user-select:none}
.fr-row:active{background:var(--surface2)}
.fr-row-left{display:flex;align-items:center;gap:.45rem;min-width:0;flex-wrap:nowrap}
.fr-row-icon{font-size:.85rem;flex-shrink:0}
.fr-row-label{font-size:.83rem;font-weight:800;color:var(--text)}
.fr-row-count{font-size:.7rem;color:var(--muted);font-weight:500}
.fr-pending-badge{background:var(--gold-bg);border:1px solid rgba(245,158,11,.3);color:var(--gold);font-size:.58rem;font-weight:800;padding:1px 6px;border-radius:5px;white-space:nowrap}
.fr-row-right{display:flex;align-items:center;gap:.55rem;flex-shrink:0}
.fr-find-pill{background:var(--pink-bg);border:1.5px solid rgba(236,72,153,.3);color:var(--pink);font-size:.65rem;font-weight:800;padding:.2rem .55rem;border-radius:7px;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent}
.fr-chev-main{color:var(--muted);font-size:.75rem;transition:transform .2s;display:inline-block}
.fr-chev-main.open{transform:rotate(180deg)}
.fr-panel{max-height:0;overflow:hidden;transition:max-height .32s cubic-bezier(.4,0,.2,1)}
.fr-panel.open{max-height:600px}
.fr-pending-lbl{font-size:.65rem;font-weight:800;color:var(--gold);text-transform:uppercase;letter-spacing:.06em;padding:.55rem 1rem .2rem;display:flex;align-items:center;gap:.3rem}
.fr-pcount{background:var(--gold-bg);color:var(--gold);padding:0 5px;border-radius:4px;font-size:.6rem}
.fr-pending-card{display:flex;align-items:center;gap:.65rem;padding:.45rem 1rem;background:var(--surface);margin:.25rem 1rem;border-radius:11px;border:1px solid rgba(245,158,11,.25)}
.fr-av{width:34px;height:34px;border-radius:10px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;overflow:hidden}
.fr-info{flex:1;min-width:0}
.fr-name{font-size:.82rem;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fr-un{font-size:.65rem;color:var(--muted);margin-top:1px}
.fr-pbtns{display:flex;gap:.3rem;flex-shrink:0}
.fr-accept{padding:.28rem .6rem;border-radius:7px;background:var(--green-bg);border:1px solid rgba(34,197,94,.3);color:var(--green);font-size:.7rem;font-weight:800;cursor:pointer;font-family:inherit}
.fr-decline{padding:.28rem .6rem;border-radius:7px;background:var(--surface2);border:1px solid var(--border);color:var(--muted);font-size:.7rem;font-weight:700;cursor:pointer;font-family:inherit}
.fr-divider{height:1px;background:var(--border);margin:.35rem 0}
.fr-item{display:flex;align-items:center;gap:.65rem;padding:.45rem 1rem;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .1s}
.fr-item:active{background:var(--surface2)}
.fr-chev{color:var(--muted);font-size:.85rem}
.fr-empty{padding:1.25rem 1rem;text-align:center;color:var(--muted);font-size:.78rem;line-height:1.5}
/* Find Friends sheet */
.ff-sheet{width:100%;max-width:560px;background:var(--bg2);border-radius:22px 22px 0 0;border-top:1px solid var(--border);display:flex;flex-direction:column;max-height:80vh;animation:sheetUp .28s cubic-bezier(.33,1,.68,1);transition:background .3s}
.ff-handle{width:36px;height:4px;border-radius:2px;background:var(--border2);margin:10px auto 0;flex-shrink:0}
.ff-head{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1.1rem .5rem;border-bottom:1px solid var(--border);flex-shrink:0}
.ff-title{font-size:.9rem;font-weight:800;color:var(--text)}
.ff-close{background:var(--surface);border:none;color:var(--muted);width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.73rem;font-weight:800;font-family:inherit;flex-shrink:0}
.ff-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}
.ff-tab{flex:1;padding:.52rem;text-align:center;font-size:.75rem;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;transition:all .15s;font-family:inherit;background:none;border-top:none;border-left:none;border-right:none}
.ff-tab.active{color:var(--pink);border-bottom-color:var(--pink)}
.ff-search-pane{display:flex;flex-direction:column;flex:1;overflow:hidden}
.ff-search-wrap{padding:.55rem 1rem;flex-shrink:0}
.ff-search{width:100%;padding:.52rem .85rem;border-radius:10px;border:1.5px solid var(--border);background:var(--input-bg);color:var(--text);font-family:inherit;font-size:.85rem}
.ff-search:focus{outline:none;border-color:var(--pink)}
.ff-list{overflow-y:auto;flex:1;padding-bottom:1rem;-webkit-overflow-scrolling:touch}
.ff-result{display:flex;align-items:center;gap:.65rem;padding:.48rem 1rem;cursor:pointer;transition:background .1s;-webkit-tap-highlight-color:transparent}
.ff-result:active{background:var(--surface2)}
.ff-r-info{flex:1;min-width:0}
.ff-r-name{font-size:.82rem;font-weight:800;color:var(--text)}
.ff-r-un{font-size:.65rem;color:var(--muted);margin-top:1px}
.ff-add-btn{padding:.28rem .65rem;border-radius:7px;border:1.5px solid rgba(236,72,153,.3);background:var(--pink-bg);color:var(--pink);font-size:.7rem;font-weight:800;cursor:pointer;font-family:inherit;white-space:nowrap;flex-shrink:0}
.ff-add-btn.pending{border-color:rgba(245,158,11,.3);background:var(--gold-bg);color:var(--gold)}
.ff-add-btn.friends{border-color:rgba(34,197,94,.3);background:var(--green-bg);color:var(--green)}
.ff-add-btn.recv{border-color:rgba(34,197,94,.3);background:var(--green-bg);color:var(--green)}
.ff-empty{padding:2rem 1rem;text-align:center;color:var(--muted);font-size:.82rem;line-height:1.5}
.ff-share-pane{flex-direction:column;flex:1;overflow-y:auto;padding:1rem;gap:.75rem;-webkit-overflow-scrolling:touch}
/* QR area (Drop I.2b customiser) */
.ff-qr-area{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.ff-qr-hint{font-size:.68rem;color:var(--muted);text-align:center;line-height:1.4}
.ff-qr-wrap{display:flex;justify-content:center;align-items:center;min-height:210px}
.ff-qr-user{font-size:.8rem;font-weight:800}
/* QR customiser controls */
.ff-cust{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:.7rem;display:flex;flex-direction:column;gap:.55rem}
.ff-cust-row{display:flex;align-items:center;gap:.5rem}
.ff-cust-lbl{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);width:50px;flex-shrink:0}
.ff-swatch-row{display:flex;gap:.4rem;align-items:center}
.ff-swatch{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s,box-shadow .15s;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.ff-frame-row{display:flex;gap:.35rem;align-items:center;overflow-x:auto;flex:1}
.ff-frame-row::-webkit-scrollbar{display:none}
.ff-frame-opt{flex-shrink:0;padding:.22rem .5rem;border-radius:7px;border:1.5px solid var(--border);background:var(--surface2);color:var(--muted);font-size:.6rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.ff-ov-row{display:flex;gap:.35rem;align-items:center;flex:1}
.ff-ov-opt{width:36px;height:36px;border-radius:9px;border:1.5px solid var(--border);background:var(--surface2);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.85rem;transition:all .15s;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.ff-link-row{display:flex;align-items:center;gap:.45rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.5rem .7rem}
.ff-link-txt{flex:1;font-size:.7rem;color:var(--muted);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ff-copy-btn{background:var(--pink-bg);border:1px solid rgba(236,72,153,.3);color:var(--pink);font-size:.7rem;font-weight:800;padding:.22rem .65rem;border-radius:7px;cursor:pointer;font-family:inherit;flex-shrink:0;white-space:nowrap}
.ff-copy-btn.copied{background:var(--green-bg);border-color:rgba(34,197,94,.3);color:var(--green)}
.ff-share-btn{padding:.62rem;border-radius:11px;border:1.5px solid rgba(236,72,153,.3);background:var(--pink-bg);color:var(--pink);font-family:inherit;font-size:.82rem;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem}
.ff-share-hint{font-size:.68rem;color:var(--muted);text-align:center;line-height:1.4}
/* Public profile page (replaces stub) */
.pub-profile-header{display:flex;align-items:center;gap:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1rem;margin-bottom:.85rem}
.pub-av-wrap{width:52px;height:52px;border-radius:14px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;overflow:hidden;border:1.5px solid var(--border)}
.pub-profile-info{flex:1;min-width:0}
.pub-un-row{font-size:.72rem;color:var(--muted);margin-top:2px}
.pub-af-row{margin-bottom:.85rem}
.pub-add-friend-btn{width:100%;padding:.65rem;border-radius:11px;border:1.5px solid rgba(236,72,153,.3);background:var(--pink-bg);color:var(--pink);font-family:inherit;font-size:.82rem;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem;-webkit-tap-highlight-color:transparent}
.pub-add-friend-btn.pending{border-color:rgba(245,158,11,.3);background:var(--gold-bg);color:var(--gold)}
.pub-add-friend-btn.friends{border-color:rgba(34,197,94,.3);background:var(--green-bg);color:var(--green)}
.pub-build-row{display:flex;align-items:center;gap:.65rem;padding:.55rem .65rem;background:var(--card);border:1px solid var(--border);border-radius:11px;margin-bottom:.35rem;cursor:pointer;transition:border-color .12s}
.pub-build-row:active{border-color:var(--border2)}
.pub-build-thumb{width:36px;height:36px;object-fit:contain;border-radius:8px;background:var(--surface);padding:3px;flex-shrink:0}
.pub-build-info{flex:1;min-width:0}
.pub-build-name{font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pub-build-sub{font-size:.62rem;color:var(--muted);margin-top:1px}
.pub-chevron{color:var(--muted);font-size:.85rem}
.pub-loading{padding:2rem 1rem;text-align:center;color:var(--muted);font-size:.82rem}
/* Friend nav badge */
.fr-nav-badge{position:absolute;top:2px;right:2px;background:var(--gold);color:#000;font-size:.48rem;font-weight:900;min-width:14px;height:14px;border-radius:7px;display:none;align-items:center;justify-content:center;padding:0 3px}
.activity-list{margin-top:.1rem}
.act-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .55rem;border-radius:10px;cursor:pointer;transition:background .12s;margin-bottom:.2rem;-webkit-tap-highlight-color:transparent}
.act-item:hover{background:var(--surface)}
.act-item:active{background:var(--surface2)}
.act-item img{width:36px;height:36px;object-fit:contain;border-radius:8px;background:var(--surface2);padding:3px;flex-shrink:0}
.act-placeholder{width:36px;height:36px;border-radius:8px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--muted);flex-shrink:0}
.act-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.act-text{font-size:.82rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.act-sub{font-size:.65rem;color:var(--muted);font-weight:500}
.act-time{font-size:.68rem;color:var(--muted);white-space:nowrap;flex-shrink:0}
.act-chev{color:var(--muted2);font-size:.8rem;flex-shrink:0;margin-left:.1rem}

/* Subsection: Confirm modal */
/* ── Onboarding Guide (Drop I.5) ── */
.ob-ov{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:450;display:none;align-items:flex-end;justify-content:center}
.ob-ov.open{display:flex}
.ob-sheet{width:100%;max-width:480px;background:var(--bg2);border-radius:26px 26px 0 0;border-top:1px solid var(--border);padding:1.5rem 1.5rem calc(1.5rem + env(safe-area-inset-bottom,0px));animation:sheetUp .3s cubic-bezier(.33,1,.68,1);transition:background .3s}
.ob-dots{display:flex;gap:.45rem;justify-content:center;margin-bottom:1.5rem}
.ob-dot{width:6px;height:6px;border-radius:3px;background:var(--border2);transition:all .3s}
.ob-dot.active{width:22px;background:var(--red)}
.ob-icon{font-size:2.8rem;display:block;text-align:center;margin-bottom:.8rem}
.ob-title{font-size:1.25rem;font-weight:900;letter-spacing:-.025em;text-align:center;margin-bottom:.5rem;line-height:1.2}
.ob-desc{font-size:.86rem;color:var(--text2);text-align:center;line-height:1.65;margin-bottom:1.1rem}
.ob-hl{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:.85rem;margin-bottom:1.1rem;display:flex;flex-direction:column;gap:.55rem}
.ob-hl-row{display:flex;align-items:center;gap:.7rem}
.ob-hl-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.88rem;flex-shrink:0}
.ob-hl-text strong{display:block;font-size:.8rem;font-weight:800}
.ob-hl-text span{font-size:.72rem;color:var(--muted)}
.ob-feats{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.1rem}
.ob-feat{display:flex;align-items:center;gap:.7rem;background:var(--surface);border-radius:11px;padding:.65rem .85rem}
.ob-feat-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.ob-feat-txt strong{font-size:.8rem;font-weight:800;display:block}
.ob-feat-txt span{font-size:.7rem;color:var(--muted)}
.ob-nav{display:flex;gap:.65rem;align-items:center;margin-top:.1rem}
.ob-skip{flex:1;font-family:inherit;font-size:.8rem;font-weight:700;color:var(--muted);background:none;border:none;cursor:pointer;text-align:left;padding:.5rem 0;transition:color .15s;-webkit-tap-highlight-color:transparent}
.ob-skip:hover{color:var(--text2)}
.ob-next{background:var(--red);color:#fff;border:none;border-radius:12px;padding:.75rem 1.6rem;font-family:inherit;font-size:.88rem;font-weight:800;cursor:pointer;display:flex;align-items:center;gap:.38rem;transition:filter .15s;white-space:nowrap}
.ob-next:hover{filter:brightness(1.1)}
.ob-next.ob-finish{background:linear-gradient(135deg,var(--red),#b91c1c);box-shadow:0 4px 16px rgba(239,68,68,.35)}
/* Replay btn on Profile */
.prof-replay-btn{display:flex;align-items:center;gap:.38rem;padding:.38rem .55rem;border-radius:8px;background:none;border:none;color:var(--muted2);font-family:inherit;font-size:.72rem;font-weight:600;cursor:pointer;margin-top:.6rem;transition:color .15s;-webkit-tap-highlight-color:transparent}
.prof-replay-btn:hover{color:var(--muted)}
/* Featured builds on signed-out home */
.da-fb-list{display:flex;flex-direction:column;gap:.55rem;padding:0 1rem .5rem}
.da-fb-card{display:flex;align-items:center;gap:.8rem;padding:.7rem .9rem;border-radius:14px;cursor:pointer;transition:opacity .15s;position:relative;overflow:hidden;min-height:72px}
.da-fb-card:active{opacity:.82}
.da-fb-sprite{width:52px;height:52px;object-fit:contain;filter:drop-shadow(0 3px 8px rgba(0,0,0,.4));flex-shrink:0;position:relative;z-index:1;image-rendering:pixelated}
.da-fb-info{flex:1;min-width:0;position:relative;z-index:1}
.da-fb-name{font-size:.85rem;font-weight:800;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.da-fb-pkmn{font-size:.68rem;color:rgba(255,255,255,.65);margin-top:1px;font-weight:600}
.da-fb-moves{display:flex;gap:.3rem;margin-top:.35rem;overflow:hidden}
.da-fb-move{font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:5px;background:rgba(255,255,255,.18);color:#fff;white-space:nowrap}
/* Browse Dex button on signed-out home */
.da-signout-btns .btn-dex{background:var(--surface2);color:var(--text2);border:1px solid var(--border2)}
.da-signout-btns .btn-dex:hover{border-color:var(--border2);color:var(--text)}

.modal-ov{position:fixed;inset:0;z-index:400;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.4);backdrop-filter:blur(2px)}
.modal-ov.open{display:flex}
.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:1.5rem;max-width:380px;width:90%;text-align:center}
.modal-box .em{font-size:2rem;margin-bottom:.5rem}
.modal-box h3{font-size:1rem;font-weight:700;margin-bottom:.3rem}
.modal-box p{font-size:.85rem;color:var(--muted);margin-bottom:1rem}
.modal-btns{display:flex;gap:.5rem;justify-content:center}

 
