:root{--navy:#00162b;--green:#2D8A4E;--green-dark:#1E6038;--white:#fff;--off-white:#F5F5F5;--grey:#7A7A7A;--radius:4px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Heebo',Helvetica,sans-serif}

/* ── PORTAL WRAP ── */
.ypds-portal-wrap{min-height:100vh;background:var(--off-white)}

/* ── PORTAL HEADER ── */
.ypds-portal-header{background:var(--navy);padding:0;position:sticky;top:0;z-index:100}
.ypds-portal-header__inner{max-width:1100px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between}
.ypds-portal-header__logo{height:36px}
.ypds-portal-header__user{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.85);font-size:14px}
.ypds-ref{background:rgba(255,255,255,.1);border-radius:12px;padding:2px 10px;font-size:12px;letter-spacing:.5px;font-family:'Jost',sans-serif}

/* ── PORTAL BODY ── */
.ypds-portal-body{max-width:1100px;margin:0 auto;padding:32px 24px}
.ypds-section-title{font-size:18px;font-weight:600;color:var(--navy);margin-bottom:16px;font-family:'Jost',sans-serif;letter-spacing:.3px}

/* ── LOGIN ── */
.ypds-login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--navy)}
.ypds-login-box{background:#fff;border-radius:8px;padding:40px;width:100%;max-width:420px}
.ypds-login-logo{text-align:center;margin-bottom:24px}
.ypds-login-logo img{height:44px}
.ypds-login-box h2{font-family:'Libre Baskerville',serif;color:var(--navy);font-size:22px;text-align:center;margin-bottom:8px}
.ypds-login-sub{color:var(--grey);text-align:center;font-size:14px;margin-bottom:24px}
.ypds-login-note{text-align:center;font-size:13px;color:var(--grey);margin-top:20px}
.ypds-login-note a{color:var(--green)}

/* ── FORMS ── */
.ypds-field{margin-bottom:16px}
.ypds-field label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:6px;font-family:'Jost',sans-serif;letter-spacing:.3px}
.ypds-field input,.ypds-field select,.ypds-textarea{width:100%;padding:10px 14px;border:1px solid #ddd;border-radius:var(--radius);font-family:inherit;font-size:15px;color:var(--navy);outline:none;transition:border-color .2s}
.ypds-field input:focus,.ypds-field select:focus,.ypds-textarea:focus{border-color:var(--green)}
.ypds-textarea{resize:vertical;min-height:80px;padding:10px 14px;width:100%}

/* ── BUTTONS ── */
.ypds-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:var(--radius);font-family:'Jost',sans-serif;font-size:14px;font-weight:600;letter-spacing:.5px;cursor:pointer;border:none;text-decoration:none;transition:background .2s,opacity .2s}
.ypds-btn--primary{background:var(--green);color:#fff}
.ypds-btn--primary:hover{background:var(--green-dark);color:#fff}
.ypds-btn--ghost{background:transparent;color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.25)}
.ypds-btn--ghost:hover{background:rgba(255,255,255,.1)}
.ypds-btn--full{width:100%;justify-content:center}
.ypds-btn--sm{padding:6px 14px;font-size:13px}

/* ── ALERTS ── */
.ypds-alert{padding:12px 16px;border-radius:var(--radius);font-size:14px;margin-bottom:16px}
.ypds-alert--error{background:#fef2f2;color:#c0392b;border:1px solid #fca5a5}
.ypds-alert--success{background:#f0fdf4;color:#166534;border:1px solid #86efac}

/* ── BADGES ── */
.ypds-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600;font-family:'Jost',sans-serif;letter-spacing:.3px;text-transform:uppercase}
.ypds-badge--enquiry{background:#f0f9ff;color:#0369a1}
.ypds-badge--active{background:#f0fdf4;color:#166534}
.ypds-badge--on_hold{background:#fefce8;color:#92400e}
.ypds-badge--completed{background:#f5f5f5;color:#666}
.ypds-badge--cancelled{background:#fef2f2;color:#c0392b}
.ypds-badge--sent{background:#f0f9ff;color:#0369a1}
.ypds-badge--paid{background:#f0fdf4;color:#166534}
.ypds-badge--overdue{background:#fef2f2;color:#c0392b}
.ypds-badge--draft{background:#f5f5f5;color:#666}

/* ── PROJECT CARDS ── */
.ypds-project-card{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:20px 24px;margin-bottom:12px}
.ypds-project-card__head{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.ypds-project-card__title{font-size:16px;font-weight:600;color:var(--navy);font-family:'Jost',sans-serif}
.ypds-project-card__stage{font-size:13px;color:var(--grey);margin-bottom:12px}
.ypds-project-card__actions{display:flex;gap:8px}

/* ── STAGE TRACKER ── */
.ypds-stage-track{display:flex;gap:0;margin:24px 0;background:#fff;border:1px solid #e5e7eb;border-radius:6px;overflow:hidden}
.ypds-stage-step{flex:1;padding:12px 8px;text-align:center;border-right:1px solid #e5e7eb;position:relative}
.ypds-stage-step:last-child{border-right:none}
.ypds-stage-step__num{width:28px;height:28px;border-radius:50%;background:#ddd;color:#666;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 6px;font-family:'Jost',sans-serif}
.ypds-stage-step__label{font-size:11px;color:var(--grey);line-height:1.3;font-family:'Jost',sans-serif}
.ypds-stage-step--done .ypds-stage-step__num{background:var(--green);color:#fff}
.ypds-stage-step--active{background:#f0fdf4}
.ypds-stage-step--active .ypds-stage-step__num{background:var(--green);color:#fff;box-shadow:0 0 0 3px rgba(45,138,78,.2)}
.ypds-stage-step--active .ypds-stage-step__label{color:var(--green);font-weight:600}

/* ── FILE GRID ── */
.ypds-file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.ypds-file-card{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:16px;text-align:center}
.ypds-file-card__icon{font-size:32px;margin-bottom:8px}
.ypds-file-card__name{font-size:13px;font-weight:600;color:var(--navy);margin-bottom:4px;word-break:break-word}
.ypds-file-card__meta{font-size:11px;color:var(--grey);margin-bottom:12px;text-transform:uppercase;letter-spacing:.3px}

/* ── MESSAGES ── */
.ypds-messages{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:16px}
.ypds-message{padding:12px 14px;border-radius:4px;max-width:80%}
.ypds-message--client{background:#f0fdf4;align-self:flex-end}
.ypds-message--admin{background:#f0f9ff;align-self:flex-start}
.ypds-message__sender{font-size:12px;font-weight:700;color:var(--navy);margin-bottom:4px;font-family:'Jost',sans-serif}
.ypds-message__text{font-size:14px;color:#333;line-height:1.5}
.ypds-message__time{font-size:11px;color:var(--grey);margin-top:4px}

/* ── TABLES ── */
.ypds-table{width:100%;border-collapse:collapse;background:#fff;border-radius:6px;overflow:hidden;border:1px solid #e5e7eb}
.ypds-table th{background:var(--navy);color:#fff;padding:12px 14px;font-family:'Jost',sans-serif;font-size:12px;letter-spacing:.5px;text-align:left}
.ypds-table td{padding:12px 14px;border-bottom:1px solid #e5e7eb;font-size:14px;color:var(--navy)}
.ypds-table tr:last-child td{border-bottom:none}
.ypds-invoice-table-wrap{overflow-x:auto}

/* ── ADMIN ── */
.ypds-admin-wrap{padding:20px}
.ypds-admin-title{font-family:'Jost',sans-serif;color:var(--navy);margin-bottom:20px}
.ypds-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.ypds-stat{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:20px;text-align:center}
.ypds-stat--alert{border-color:var(--green)}
.ypds-stat-num{display:block;font-size:32px;font-weight:700;color:var(--navy);font-family:'Jost',sans-serif}
.ypds-stat-label{font-size:12px;color:var(--grey);text-transform:uppercase;letter-spacing:.5px}
.ypds-card{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:20px}
.ypds-card h3{font-family:'Jost',sans-serif;font-size:14px;letter-spacing:.3px;margin-bottom:12px;color:var(--navy)}
.ypds-empty{color:var(--grey);font-size:14px;padding:20px;text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .ypds-stat-grid{grid-template-columns:1fr 1fr}
  .ypds-stage-track{flex-wrap:wrap}
  .ypds-stage-step{min-width:50%}
  .ypds-portal-body{padding:16px}
}
@media(max-width:480px){
  .ypds-stat-grid{grid-template-columns:1fr}
  .ypds-login-box{padding:24px 20px}
}