/* Adrem Surveys — customer portal (clients.*). Light, top-bar-only surface.
   Figma frames P0 904:13 · P1 885:13 · P2 888:13 · P3 892:13 · not-ready 892:62. */
:root { --pbg:#F7F9FC; --pcard:#fff; --pline:#E6EAF0; --pink:#16202B; --pmut:#69788A;
        --pblue:#1D6FE0; --pteal:#0E7490; --pgreen:#1C9E6A; --pamber:#B45309; }
* { box-sizing:border-box; }
body { margin:0; font:16px/1.55 -apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
       color:var(--pink); background:var(--pbg); }
a { color:var(--pblue); }

/* top bar */
.ptopbar { display:flex; align-items:center; justify-content:space-between; gap:16px;
           background:#fff; border-bottom:1px solid var(--pline); padding:14px 28px; }
.pbrand { display:flex; align-items:center; gap:9px; text-decoration:none; color:var(--pink);
          font-size:17px; }
.pdim { color:#9AA7B6; }
.pmark { width:22px; height:22px; border-radius:7px; background:var(--pblue); display:inline-block; }
.pmark.big { width:36px; height:36px; border-radius:10px; margin:0 auto 14px; display:block; }
.pjobname { font-weight:600; }
.pright { display:flex; align-items:center; gap:14px; }
.plogout { font-size:13px; color:var(--pmut); text-decoration:none; }
.pstatus { background:#DCEEF5; color:var(--pteal); font-size:13px; font-weight:600;
           padding:6px 14px; border-radius:16px; white-space:nowrap; }

/* tabs */
.ptabs { display:flex; gap:22px; padding:0 28px; background:#fff;
         border-bottom:1px solid var(--pline); }
.ptabs a { padding:10px 2px; font-size:14px; color:var(--pmut); text-decoration:none;
           border-bottom:2px solid transparent; }
.ptabs a.on, .ptabs a:hover { color:var(--pink); border-bottom-color:var(--pblue); }

/* layout */
.pwrap { max-width:760px; margin:0 auto; padding:36px 24px 48px; }
.pfoot { text-align:center; color:var(--pmut); font-size:13px; padding:0 24px 40px; }
h1 { font-size:28px; margin:0 0 6px; }
h2 { font-size:19px; margin:30px 0 12px; }
h3 { font-size:16px; margin:0 0 8px; }
.plede { margin:0 0 22px; }
.pmuted { color:var(--pmut); } .psmall { font-size:13px; } .pcenter { text-align:center; }

.pcard { background:var(--pcard); border:1px solid var(--pline); border-radius:12px;
         padding:22px 26px; margin-bottom:18px; box-shadow:0 1px 2px rgba(16,24,40,.04); }

/* banners + chips */
.pbanner { border-radius:10px; padding:12px 16px; margin:12px 0; font-size:14px; }
.pbanner.pok { background:#E7F6EE; color:#0F6B46; }
.pbanner.perr { background:#FDEAE7; color:#8A1F08; }
.pbanner.pwarnb { background:#FDF3E3; color:var(--pamber); border-left:4px solid #E8A23D; }
.pchip { display:inline-block; font-size:13px; font-weight:600; padding:5px 12px;
         border-radius:14px; }
.pchip.pamber { background:#FDF3E3; color:var(--pamber); }
.pchip.pgreen { background:#E7F6EE; color:var(--pgreen); }

/* P0 login */
.plogin { max-width:440px; margin:48px auto 0; }
.pauth { padding:32px 40px; text-align:center; }
.pauth h1 { font-size:21px; margin:0 0 4px; }
.pauth h2 { font-size:16px; margin:0 0 4px; }
.pauth form { text-align:left; margin-top:18px; }
.pauth label { display:block; font-size:13px; font-weight:600; margin:14px 0 0; }
.pauth input { width:100%; margin-top:6px; padding:12px 14px; font-size:15px;
               border:1px solid var(--pline); border-radius:9px; background:#F2F5F9; }
.pbtn { width:100%; margin-top:20px; padding:13px; font-size:15px; font-weight:600; border:0;
        border-radius:9px; background:var(--pblue); color:#fff; cursor:pointer; }
.plink { display:block; width:100%; background:none; border:0; color:var(--pblue);
         font-size:14px; font-weight:600; margin-top:14px; cursor:pointer; }

/* jobs list */
.pjobcard { display:flex; align-items:center; justify-content:space-between; gap:14px;
            text-decoration:none; color:var(--pink); }
.pjobcard:hover { border-color:#C9D8EE; }
.pjobtitle { font-weight:600; font-size:17px; }

/* P1 status */
.pnow { display:flex; gap:14px; align-items:flex-start; }
.pnow h3 { font-size:18px; }
.pnow p { margin:4px 0; }
.pnowdot { width:11px; height:11px; border-radius:50%; background:var(--pteal); margin-top:7px;
           flex:none; }
.ptimeline { list-style:none; margin:0; padding:4px 0; }
.ptimeline li { display:flex; gap:16px; padding:0 0 26px; position:relative; }
.ptimeline li:last-child { padding-bottom:0; }
.ptimeline li::before { content:""; position:absolute; left:8px; top:22px; bottom:0;
                        width:2px; background:var(--pline); }
.ptimeline li:last-child::before { display:none; }
.ptimeline li.done::before { background:#BFE7D4; }
.pdot { width:18px; height:18px; border-radius:50%; flex:none; margin-top:2px;
        border:2px solid #C8D2DE; background:#fff; }
li.done .pdot { background:var(--pgreen); border-color:var(--pgreen); }
li.now .pdot { background:var(--pteal); border-color:var(--pteal); }
li.todo .psteptitle { color:var(--pmut); }
.psteptitle { font-weight:600; }
.pnowchip { background:#DCEEF5; color:var(--pteal); font-size:12px; font-weight:600;
            border-radius:12px; padding:3px 10px; margin-left:10px; vertical-align:1px; }

/* P2 evidence */
.pphotogrid { display:grid; grid-template-columns:repeat(auto-fill, minmax(160px, 1fr));
              gap:16px; }
.pphoto { margin:0; }
.pphoto img { width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:10px;
              background:#E2E8F0; display:block; }
.pphoto figcaption { font-size:13px; color:var(--pmut); margin-top:6px; }
.pwalk { display:flex; gap:22px; flex-wrap:wrap; }
.pvideo { flex:1 1 320px; }
.pvideo video { width:100%; border-radius:10px; background:#0F1B2D; }
.pnovideo { display:flex; align-items:center; justify-content:center; height:200px;
            border-radius:10px; background:#0F1B2D; color:#9AA7B6; font-size:14px; }
.ptranscript { flex:1 1 240px; font-size:14px; }
.pplanrow { display:flex; gap:28px; flex-wrap:wrap; }
.pplans { flex:1 1 320px; display:flex; gap:18px; flex-wrap:wrap; }
.pplan { margin:0; }
.pplan svg { background:#F2F5F9; border:1px solid var(--pline); border-radius:10px; }
.pplan figcaption { font-size:13px; color:var(--pmut); margin-top:5px; }
.pplanside { flex:1 1 200px; }
.psidehead { font-size:13px; font-weight:600; margin:14px 0 7px; }
.psidehead:first-child { margin-top:0; }
.punplaced { margin:0; padding-left:18px; font-size:14px; color:var(--pmut); }

/* P3 works + not-ready */
.pworks ul { margin:0; padding-left:20px; }
.pworks li { padding:4px 0; }
.pworks li::marker { color:var(--pblue); }
.pnotready { max-width:600px; margin:60px auto 0; }
.pnotready .pcard { padding:48px 40px; }
.pdocicon { width:84px; height:84px; margin:0 auto 22px; border-radius:50%; background:#E8F0FC;
            display:flex; flex-direction:column; align-items:center; justify-content:center;
            gap:7px; }
.pdocicon span { display:block; height:6px; border-radius:3px; background:#8FB4EA; }
.pdocicon span:first-child { width:36px; background:#4D86DB; }
.pdocicon span:last-child { width:24px; }

/* job picker (920:13) */
.pjobright { display:flex; align-items:center; gap:12px; }
.pchev { color:#9AA7B6; font-size:20px; }

/* check-your-email (918:13) */
.pbrandrow { display:flex; align-items:center; justify-content:center; gap:8px; font-size:17px;
             margin-bottom:18px; }
.ptick { width:56px; height:56px; border-radius:50%; background:#E7F6EE; color:#1C9E6A;
         font-size:26px; line-height:56px; margin:0 auto 16px; }
.pbtn.ghost { display:block; width:100%; margin-top:16px; background:#fff; color:var(--pblue);
              border:1px solid var(--pline); text-align:center; text-decoration:none;
              padding:12px 0; border-radius:22px; font-weight:600; font-size:15px; }

/* job summary (926:13) */
.psummary { margin:4px 0; font-size:16px; }
.pwork h3 { margin-bottom:6px; }
.pwork p { margin:0 0 10px; color:#3D4B5C; }
.pareatag { display:inline-block; background:#EEF1F5; color:#475467; font-size:13px;
            padding:4px 12px; border-radius:8px; }

/* key moments + notes */
.pnostill { display:flex; align-items:center; justify-content:center; aspect-ratio:4/3;
            border-radius:10px; background:#E2E8F0; color:#69788A; font-size:14px; }
.pnote { margin-top:4px; font-size:14px; color:#69788A; background:#F2F5F9; border-radius:8px;
         padding:7px 11px; }
