/* Foofie Fashion Files — page, teaser, modals */
:root{ --fpf-accent:#534AB7; --fpf-accent-d:#3c3489; --fpf-ink:#1f2430; --fpf-muted:#7a8194; --fpf-line:#eceef5; --fpf-danger:#c0395e; }

.fpf-notice,.fpf-loading{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:#fff;border-radius:14px;padding:22px;text-align:center;color:var(--fpf-muted);max-width:640px;margin:16px auto}

/* ── Page ── */
.fpf-page{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;max-width:560px;margin:0 auto;color:var(--fpf-ink)}
.fpf-hero{position:relative;overflow:hidden;background:var(--fpf-accent);border-radius:18px;padding:22px 24px;margin-bottom:18px;color:#fff;box-shadow:0 6px 22px rgba(83,74,183,.22)}
.fpf-hero-wm{position:absolute;right:2px;top:-26px;font-size:140px;line-height:1;opacity:.10;pointer-events:none;user-select:none}
.fpf-back{display:inline-flex;align-items:center;gap:4px;color:#dcd9f7;text-decoration:none;font-weight:600;font-size:13px;position:relative;z-index:1}
.fpf-back:hover{color:#fff}
.fpf-hero-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-top:14px;position:relative;z-index:1}
.fpf-hero-left{min-width:0}
.fpf-hero-brand{display:flex;align-items:center;gap:11px}
.fpf-hero-ico{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.16);display:inline-flex;align-items:center;justify-content:center;font-size:21px;flex:none}
.fpf-hero-title{margin:0;color:#fff;font-size:27px;font-weight:800;letter-spacing:-.4px;line-height:1.1}
.fpf-hero-tag{margin:12px 0 0;color:#dcd9f7;font-size:14px;line-height:1.5;max-width:62ch}
.fpf-share-btn{flex:none;display:inline-flex;align-items:center;gap:6px;background:#F0B429;color:#5A3D04;border:none;border-radius:999px;padding:11px 20px;font-size:14px;font-weight:800;cursor:pointer;white-space:nowrap;font-family:inherit}
.fpf-share-btn:hover{background:#e0a51f}

.fpf-grid{display:flex;flex-direction:column;gap:22px}
.fpf-empty,.fpf-loading{grid-column:1/-1;text-align:center;color:var(--fpf-muted);padding:30px}
.fpf-more{display:block;margin:18px auto 0;background:#fff;border:1px solid var(--fpf-line);border-radius:22px;padding:10px 22px;font-size:14px;font-weight:700;color:var(--fpf-accent);cursor:pointer;font-family:inherit}

/* ── Card ── */
.fpf-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.07);display:flex;flex-direction:column}
.fpf-photo{display:block;background:#eef0f6;cursor:zoom-in}
.fpf-card-body{padding:12px 14px;display:flex;flex-direction:column;gap:8px}
.fpf-byline{display:flex;align-items:center;gap:10px}
.fpf-by-meta{flex:1;min-width:0}
.fpf-av{width:30px;height:30px;border-radius:50%;background:#ddd center/cover no-repeat;flex:none}
.fpf-av-ini{display:flex;align-items:center;justify-content:center;background:var(--fpf-accent);color:#fff;font-size:12px;font-weight:700}
.fpf-by-name{font-weight:700;font-size:14px}
.fpf-by-time{color:var(--fpf-muted);font-size:12px;margin-left:6px}
.fpf-report{margin-left:auto;background:none;border:none;color:#b08900;opacity:.5;font-size:13px;cursor:pointer;padding:2px 4px}
.fpf-report:hover{opacity:1}
.fpf-caption{font-size:14px;line-height:1.45}

/* ── Where I got it ── */
.fpf-links{display:flex;flex-direction:column;gap:5px;background:#f7f8fc;border:1px solid var(--fpf-line);border-radius:10px;padding:8px 10px}
.fpf-links-h{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--fpf-muted)}
.fpf-link{font-size:13px;color:var(--fpf-accent);text-decoration:none;font-weight:600;word-break:break-word}
.fpf-link:hover{text-decoration:underline}
.fpf-link-plain{color:var(--fpf-ink);cursor:default}
.fpf-link-plain:hover{text-decoration:none}

/* ── Reactions ── */
.fpf-react-bar{display:flex;gap:6px;flex-wrap:wrap}
.fpf-react{background:#f1f2f7;border:1px solid transparent;border-radius:16px;padding:3px 9px;font-size:15px;cursor:pointer;line-height:1;display:inline-flex;align-items:center;gap:4px}
.fpf-react:hover{background:#e7e8f2}
.fpf-react-on{background:#eceafd;border-color:var(--fpf-accent)}
.fpf-react-c{font-size:12px;font-weight:700;color:var(--fpf-ink)}

/* ── Modals (report + share) ── */
.fpf-modal-ov{position:fixed;inset:0;z-index:100001;background:rgba(20,18,40,.55);display:flex;align-items:center;justify-content:center;padding:18px}
.fpf-modal{background:#fff;border-radius:16px;width:100%;max-width:440px;max-height:92vh;overflow:auto;padding:20px;box-shadow:0 24px 70px rgba(0,0,0,.4);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif}
.fpf-modal-title{font-weight:800;font-size:18px;margin-bottom:4px}
.fpf-modal-sub{font-size:13px;color:var(--fpf-muted);margin:0 0 12px}
.fpf-modal-reason,.fpf-cap{width:100%;box-sizing:border-box;border:1px solid var(--fpf-line);border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit;outline:none;resize:vertical}
.fpf-modal-reason{min-height:80px}
.fpf-cap{min-height:54px}
.fpf-modal-reason:focus,.fpf-cap:focus{border-color:var(--fpf-accent)}
.fpf-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}
.fpf-btn-ghost{background:#eee;border:none;border-radius:10px;padding:9px 16px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;color:#444}
.fpf-btn-primary{background:var(--fpf-accent);color:#fff;border:none;border-radius:10px;padding:9px 18px;font-size:14px;font-weight:800;cursor:pointer;font-family:inherit}
.fpf-btn-primary:disabled{opacity:.6}
.fpf-btn-danger{background:var(--fpf-danger);color:#fff;border:none;border-radius:10px;padding:9px 18px;font-size:14px;font-weight:800;cursor:pointer;font-family:inherit}
.fpf-btn-danger:disabled{opacity:.6}

/* ── Share modal specifics ── */
.fpf-photo-pick{display:flex;align-items:center;justify-content:center;height:120px;border:2px dashed #cfd2e0;border-radius:12px;color:var(--fpf-muted);font-weight:600;cursor:pointer;margin-bottom:10px}
.fpf-photo-pick:hover{border-color:var(--fpf-accent);color:var(--fpf-accent)}
.fpf-preview{width:100%;max-height:240px;object-fit:cover;border-radius:12px;background:#eef0f6;margin-bottom:10px;display:block}
.fpf-cap-count{font-size:11px;color:var(--fpf-muted);text-align:right;margin:2px 0 10px}
.fpf-links-edit{border-top:1px solid var(--fpf-line);padding-top:12px;margin-top:4px}
.fpf-le-h{font-size:13px;font-weight:700;margin-bottom:8px}
.fpf-le-hint{font-weight:400;color:var(--fpf-muted);font-size:12px}
.fpf-lrow{position:relative;display:flex;flex-direction:column;gap:6px;margin-bottom:10px;padding:10px;padding-right:30px;border:1px solid var(--fpf-line);border-radius:10px;background:#fafbfe}
.fpf-lrow input{width:100%;box-sizing:border-box;border:1px solid var(--fpf-line);border-radius:8px;padding:8px 9px;font-size:13px;font-family:inherit;outline:none;background:#fff}
.fpf-lrow input:focus{border-color:var(--fpf-accent)}
.fpf-l-x{position:absolute;top:6px;right:6px;background:none;border:none;color:var(--fpf-muted);font-size:14px;cursor:pointer;padding:2px 5px;line-height:1}
.fpf-l-x:hover{color:var(--fpf-danger)}
.fpf-link-brand{color:var(--fpf-muted);font-weight:600}
.fpf-litem{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fpf-code{display:inline-flex;align-items:center;gap:6px;background:#fff7e6;border:1px dashed #e0a51f;color:#7a5600;border-radius:8px;padding:3px 9px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;line-height:1.4}
.fpf-code:hover{background:#fdeecb}
.fpf-code-ic{font-size:12px}
.fpf-code-val{font-family:ui-monospace,Menlo,Consolas,monospace;letter-spacing:.3px}
.fpf-code-copy{font-size:10px;font-weight:800;color:#b07c12;text-transform:uppercase;letter-spacing:.4px}
.fpf-code-done{background:#e6f7ed;border-color:#36a76a;color:#1f7a4d}
.fpf-code-done .fpf-code-copy{color:#1f7a4d}
.fpf-add-link{padding:6px 12px;font-size:13px;margin-top:2px}
.fpf-share-note{font-size:12px;color:var(--fpf-muted);font-style:italic;margin:12px 0 0}

/* ── Lightbox ── */
.fpf-lb{position:fixed;inset:0;z-index:100002;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(12,10,28,.9);opacity:0;transition:opacity .18s;cursor:zoom-out}
.fpf-lb-show{opacity:1}
.fpf-lb-img{max-width:94vw;max-height:90vh;border-radius:14px;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.fpf-lb-x{position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:50%;border:none;background:#fff;color:#333;font-size:18px;font-weight:700;cursor:pointer}

/* ── Dashboard teaser (uses portal .fcp-section-card shell) ── */
.fpf-teaser-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.fpf-teaser-link{margin-left:auto;color:var(--fpf-accent);font-weight:700;font-size:13px;text-decoration:none}
.fpf-teaser-link:hover{text-decoration:underline}
.fpf-teaser-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.fpf-teaser-thumb{aspect-ratio:1/1;border-radius:10px;background:#eef0f6 center/cover no-repeat;display:block}
.fpf-teaser-empty{color:var(--fpf-muted);font-size:13px}
.fpf-teaser-cta{grid-column:1/-1;display:block;text-align:center;color:var(--fpf-accent);font-weight:700;text-decoration:none;padding:10px;border:1px dashed #cfd2e0;border-radius:10px}
.fpf-teaser-cta:hover{background:#f7f8fc}

@media(max-width:600px){
  .fpf-grid{gap:16px}
  .fpf-teaser-row{grid-template-columns:repeat(4,1fr)}
  .fpf-hero{padding:18px 18px}
  .fpf-hero-row{flex-direction:column;align-items:stretch;gap:14px}
  .fpf-hero-title{font-size:22px}
  .fpf-share-btn{width:100%;justify-content:center;padding:12px 20px}
  .fpf-hero-wm{font-size:110px}
}

/* ── Phase 2: filter, featured, park chip, comments ── */
.fpf-filter-label{color:var(--fpf-muted);font-size:12px;font-weight:700;margin:0 4px 8px}
.fpf-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.fpf-fbtn{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid var(--fpf-line);border-radius:999px;padding:8px 15px;font-size:13px;font-weight:600;color:var(--fpf-ink);cursor:pointer;font-family:inherit}
.fpf-fbtn:hover{border-color:var(--fpf-accent);color:var(--fpf-accent)}
.fpf-fbtn-pin{font-size:11px}
.fpf-fbtn-on,.fpf-fbtn-on:hover{background:var(--fpf-accent);color:#fff;border-color:var(--fpf-accent)}
.fpf-featured{margin-bottom:16px}
.fpf-featured:empty{display:none}
.fpf-featured .fpf-card{max-width:none;margin:0}
.fpf-card{position:relative}
.fpf-card-feat{border:2px solid #f0c040}
.fpf-ribbon{position:absolute;top:12px;left:12px;z-index:2;background:#F0B429;color:#5A3D04;font-size:12px;font-weight:800;padding:4px 11px;border-radius:999px;box-shadow:0 2px 8px rgba(0,0,0,.28)}
.fpf-chips{display:flex;gap:6px;flex-wrap:wrap}
.fpf-park{flex:none;display:inline-flex;align-items:center;gap:3px;background:#eef2ff;color:#3a3a8a;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;white-space:nowrap}
.fpf-park-select{width:100%;box-sizing:border-box;border:1px solid var(--fpf-line);border-radius:10px;padding:9px 11px;font-size:14px;font-family:inherit;margin-bottom:10px;background:#fff}
.fpf-cmt-toggle{align-self:flex-start;background:none;border:none;color:var(--fpf-muted);font-size:13px;font-weight:700;cursor:pointer;padding:2px 0;font-family:inherit}
.fpf-cmt-toggle:hover{color:var(--fpf-accent)}
.fpf-cmt-wrap{border-top:1px solid var(--fpf-line);margin-top:4px;padding-top:10px}
.fpf-cmt-loading{color:var(--fpf-muted);font-size:13px;padding:6px 0}
.fpf-cmt-list{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}
.fpf-cmt{display:flex;gap:8px;align-items:flex-start}
.fpf-cmt .fpf-av{width:26px;height:26px;font-size:11px}
.fpf-cmt-main{flex:1;min-width:0}
.fpf-cmt-head{display:flex;align-items:baseline;gap:8px}
.fpf-cmt-name{font-weight:700;font-size:13px}
.fpf-cmt-time{color:var(--fpf-muted);font-size:11px}
.fpf-cmt-body{font-size:13.5px;line-height:1.4;word-break:break-word}
.fpf-cmt-del,.fpf-cmt-rep{background:none;border:none;cursor:pointer;font-size:12px;opacity:.5;padding:2px 4px;flex:none}
.fpf-cmt-del:hover,.fpf-cmt-rep:hover{opacity:1}
.fpf-cmt-add{display:flex;gap:6px}
.fpf-cmt-input{flex:1;min-width:0;border:1px solid var(--fpf-line);border-radius:16px;padding:7px 12px;font-size:13px;font-family:inherit;outline:none}
.fpf-cmt-input:focus{border-color:var(--fpf-accent)}
.fpf-cmt-send{background:var(--fpf-accent);color:#fff;border:none;border-radius:16px;padding:7px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}
.fpf-ver{text-align:center;color:#b9bdca;font-size:11px;margin-top:18px}


/* ── Photos: uniform 4:5 frame + swipe carousel ── */
.fpf-frame{aspect-ratio:4/5;overflow:hidden;background:#000}
.fpf-frame .fpf-photo{width:100%;height:100%;object-fit:cover}
.fpf-carousel{position:relative;aspect-ratio:4/5;overflow:hidden;background:#000}
.fpf-track{display:flex;height:100%;transition:transform .25s ease;will-change:transform}
.fpf-slide{flex:0 0 100%;width:100%;height:100%;object-fit:cover}
.fpf-arrow{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;border:none;background:rgba(255,255,255,.85);color:#222;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(0,0,0,.25)}
.fpf-arrow:hover{background:#fff}
.fpf-prev{left:8px}.fpf-next{right:8px}
.fpf-dots{position:absolute;bottom:10px;left:0;right:0;display:flex;justify-content:center;gap:6px}
.fpf-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.55);border:none;padding:0;cursor:pointer}
.fpf-dot.on{background:#fff}
.fpf-count{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.55);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:11px}

/* ── Share: photo tray (up to 3) ── */
.fpf-photos{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.fpf-thumb{position:relative;width:84px;aspect-ratio:4/5;border-radius:10px;overflow:hidden;background:#eef0f6}
.fpf-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.fpf-thumb-x{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;border:none;background:rgba(0,0,0,.6);color:#fff;font-size:11px;cursor:pointer;line-height:1;padding:0}
.fpf-thumb-tag{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.55);color:#fff;font-size:9px;font-weight:700;text-align:center;letter-spacing:.4px;text-transform:uppercase;padding:1px}
.fpf-add-photo{width:84px;aspect-ratio:4/5;border:2px dashed #cfd2e0;border-radius:10px;background:#fff;color:var(--fpf-muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-family:inherit}
.fpf-add-photo:hover{border-color:var(--fpf-accent);color:var(--fpf-accent)}
.fpf-add-photo-ico{font-size:22px;line-height:1}
.fpf-add-photo-t{font-size:11px;font-weight:600}

/* ── Crop tool ── */
.fpf-crop-ov{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:100003;display:flex;align-items:center;justify-content:center;padding:16px}
.fpf-crop{background:#fff;border-radius:16px;padding:16px;width:100%;max-width:360px;box-shadow:0 12px 40px rgba(0,0,0,.35)}
.fpf-crop-title{font-weight:800;font-size:17px;margin-bottom:12px;text-align:center}
.fpf-crop-stage{position:relative;width:min(78vw,300px);aspect-ratio:4/5;margin:0 auto;overflow:hidden;border-radius:12px;background:#000;touch-action:none;cursor:grab}
.fpf-crop-img{position:absolute;top:0;left:0;max-width:none;user-select:none;-webkit-user-drag:none;pointer-events:none}
.fpf-crop-hint{text-align:center;color:var(--fpf-muted);font-size:12px;margin:8px 0 4px}
.fpf-crop-zoom{display:flex;align-items:center;gap:10px;margin:6px 0 14px;color:var(--fpf-muted)}
.fpf-crop-zoom input[type=range]{flex:1}
