﻿:root {
  --s360-primary: #0064a9;
  --s360-accent: #00b0e9;
  --s360-bg-1: #eaf6ff;
  --s360-bg-2: #d6eeff;
  --s360-card: #ffffff;
  --s360-line: #b7d6ea;
  --s360-text: #11456d;
  --s360-text-soft: #5e7e95;
  --s360-ok: #17a866;
  --s360-pending: #f2b51f;
}

#system360-client-portal {
  font-family: "Segoe UI", Tahoma, Arial, sans-serif;
  color: var(--s360-text);
}

.s360c-wrap {
  max-width: 920px;
  margin: 16px auto;
  padding: 10px;
  background: linear-gradient(180deg, var(--s360-bg-1) 0%, var(--s360-bg-2) 100%);
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.85);
  box-shadow: 0 16px 38px rgba(0, 82, 138, 0.16);
}

.s360c-header {
  text-align: center;
  margin-bottom: 10px;
}

.s360c-main-logo {
  width: min(95%, 480px);
  max-height: 110px;
  object-fit: contain;
}

.s360c-cnsf-row {
  margin-top: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 15px;
  color: #1f4f70;
  font-weight: 600;
  flex-wrap: wrap;
}

.s360c-cnsf-logo {
  height: 28px;
  width: auto;
}

.s360c-card {
  background: var(--s360-card);
  border: 1px solid var(--s360-line);
  border-radius: 14px;
  padding: 14px;
  box-shadow: 0 8px 20px rgba(0, 100, 169, 0.08);
}

.s360c-card + .s360c-card,
.s360c-card + .s360c-footer,
.s360c-notice + .s360c-card {
  margin-top: 12px;
}

.s360c-loading,
.s360c-error {
  text-align: center;
  font-weight: 700;
  padding: 20px;
}

.s360c-error {
  border-color: #efb6b6;
  color: #a52222;
  background: #fff3f3;
}

.s360c-notice {
  margin-top: 8px;
  border: 1px solid #9ad8b5;
  color: #0f6a3b;
  background: #edfdf4;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 600;
  text-align: center;
}

.s360c-customer-strip {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 12px;
  align-items: center;
}

.s360c-customer-left span {
  color: var(--s360-text-soft);
  font-size: 15px;
}

.s360c-customer-left h2 {
  margin: 6px 0 0;
  font-size: clamp(22px, 4vw, 34px);
  line-height: 1.08;
  color: var(--s360-primary);
}

.s360c-advisor-box {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid #b6d9ee;
  background: #f7fcff;
}

.s360c-advisor-box img {
  width: 78px;
  height: 78px;
  border-radius: 12px;
  object-fit: cover;
}

.s360c-advisor-box small {
  display: inline-block;
  padding: 3px 7px;
  border-radius: 999px;
  background: #daf5e8;
  color: #17814b;
  font-weight: 800;
  letter-spacing: .2px;
}

.s360c-advisor-box h3 {
  margin: 5px 0 4px;
  font-size: 20px;
  line-height: 1.05;
}

.s360c-advisor-box p {
  margin: 1px 0;
  font-size: 13px;
  color: #4a6f89;
}

.s360c-process-card {
  text-align: center;
}

.s360c-clock {
  width: 110px;
  height: 110px;
  object-fit: contain;
  margin: 0 auto 6px;
  display: block;
}

.s360c-process-card h2 {
  margin: 0;
  color: #174d84;
  font-size: clamp(28px, 5vw, 36px);
  line-height: 1;
}

.s360c-process-card h3 {
  margin: 4px 0 12px;
  color: #24556f;
  letter-spacing: .5px;
  font-size: clamp(16px, 3vw, 22px);
}

.s360c-steps-row {
  display: grid;
  gap: 8px;
  position: relative;
  margin-bottom: 12px;
}

.s360c-steps-row::before {
  content: "";
  position: absolute;
  left: 4%;
  right: 4%;
  top: 28px;
  height: 4px;
  border-radius: 999px;
  background: #deebf5;
  z-index: 0;
}

.s360c-steps3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.s360c-steps6 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.s360c-step-item {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 4px;
}

.s360c-step-item span {
  font-size: 13px;
  font-weight: 700;
  color: #2d5f82;
  line-height: 1.1;
}

.s360c-step-item small {
  color: #6b8ca3;
  font-size: 11px;
  font-weight: 700;
}

.s360c-step-dot {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 2px solid #b9d5e9;
  background: #fff;
  color: #6b8ca3;
  font-weight: 800;
}

.s360c-step-dot.is-done {
  border-color: #91d331;
  background: #d4f37f;
  color: #175079;
}

.s360c-status-box {
  margin-top: 4px;
  border: 1px solid var(--s360-line);
  border-radius: 12px;
  background: #f8fcff;
  text-align: left;
  padding: 12px;
}

.s360c-status-box h4 {
  margin: 0 0 8px;
  font-size: 22px;
  color: #1a4d86;
}

.s360c-status-box ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 7px;
}

.s360c-status-box li {
  padding-left: 28px;
  position: relative;
  font-size: 20px;
  line-height: 1.22;
  font-weight: 600;
}

.s360c-status-box li::before {
  content: "\21BB";
  position: absolute;
  left: 0;
  top: 0;
  font-size: 18px;
  color: var(--s360-pending);
}

.s360c-status-box li.done::before {
  content: "\2713";
  color: var(--s360-ok);
  font-weight: 900;
}

.s360c-client-actions h4,
.s360c-office-card h3 {
  margin: 0 0 10px;
  color: #164d7d;
  font-size: 20px;
}

.s360c-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.s360c-form-grid label {
  display: grid;
  gap: 6px;
}

.s360c-form-grid span {
  font-size: 12px;
  color: #4f7590;
  font-weight: 700;
}

.s360c-form-grid input,
.s360c-form-grid select {
  border: 1px solid var(--s360-line);
  border-radius: 11px;
  padding: 9px 11px;
  font-size: 14px;
  background: #fff;
  color: #1d4a6e;
}

.s360c-btn-row {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.s360c-btn {
  border: 0;
  border-radius: 999px;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 800;
  color: #fff;
  cursor: pointer;
  background: linear-gradient(90deg, var(--s360-primary), var(--s360-accent));
  box-shadow: 0 8px 18px rgba(0, 108, 180, 0.25);
}

.s360c-btn:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.s360c-btn-sec {
  background: linear-gradient(90deg, #168e56, #1fb06a);
}

.s360c-divider {
  height: 1px;
  margin: 12px 0;
  background: #d6e8f5;
}

.s360c-office-card p {
  margin: 0 0 10px;
  color: #55778f;
}

.s360c-office-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.s360c-office-grid a {
  text-decoration: none;
  color: #165889;
  font-weight: 700;
  border: 1px solid #b6d7ec;
  border-radius: 10px;
  background: #f8fcff;
  padding: 9px 11px;
  text-align: center;
}

.s360c-footer {
  margin-top: 12px;
  text-align: center;
  padding: 10px 6px;
}

.s360c-footer img {
  width: min(95%, 430px);
  max-height: 78px;
  object-fit: contain;
}

.s360c-footer p {
  margin: 6px auto 0;
  max-width: 800px;
  color: #3d627e;
  font-size: 12px;
  line-height: 1.3;
}

.s360c-confetti-canvas {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  z-index: 9999;
}

@media (max-width: 860px) {
  .s360c-customer-strip { grid-template-columns: 1fr; }
  .s360c-steps6 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .s360c-status-box li { font-size: 16px; }
}

@media (max-width: 640px) {
  .s360c-wrap { padding: 8px; margin: 8px auto; border-radius: 14px; }
  .s360c-card { padding: 11px; border-radius: 12px; }
  .s360c-form-grid { grid-template-columns: 1fr; }
  .s360c-steps3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .s360c-steps6 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .s360c-office-grid { grid-template-columns: 1fr 1fr; }
  .s360c-process-card h2 { font-size: 30px; }
  .s360c-process-card h3 { font-size: 17px; }
  .s360c-status-box h4 { font-size: 19px; }
  .s360c-status-box li { font-size: 16px; }
  .s360c-main-logo { max-height: 90px; }
}

/* ===== APPLE DESIGN SYSTEM (CLIENT PORTAL) ===== */
#system360-client-portal {
  --cp-bg: #f3f5f8;
  --cp-surface: rgba(255, 255, 255, 0.9);
  --cp-surface-strong: rgba(255, 255, 255, 0.96);
  --cp-border: rgba(17, 24, 39, 0.1);
  --cp-text: #111827;
  --cp-soft: #6b7280;
  --cp-accent: #0a84ff;
  --cp-accent-soft: rgba(10, 132, 255, 0.14);
  --cp-ok: #34c759;
  --cp-radius: 14px;
  --cp-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
  font-family: "SF Pro Text", "SF Pro Display", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--cp-text);
}

@media (prefers-color-scheme: dark) {
  #system360-client-portal {
    --cp-bg: #11141a;
    --cp-surface: rgba(29, 34, 43, 0.9);
    --cp-surface-strong: rgba(34, 40, 50, 0.95);
    --cp-border: rgba(255, 255, 255, 0.12);
    --cp-text: #f2f4f8;
    --cp-soft: #a9b1bd;
    --cp-accent: #4aa3ff;
    --cp-accent-soft: rgba(74, 163, 255, 0.18);
    --cp-ok: #4be071;
    --cp-shadow: 0 16px 36px rgba(0, 0, 0, 0.36);
  }
}

.s360c-wrap {
  max-width: min(1080px, calc(100vw - 20px));
  background:
    radial-gradient(900px 520px at -5% -15%, rgba(10,132,255,.12), transparent 58%),
    linear-gradient(180deg, color-mix(in srgb, var(--cp-bg) 90%, white), var(--cp-bg)) !important;
  border: 1px solid var(--cp-border) !important;
  border-radius: 18px !important;
  box-shadow: var(--cp-shadow) !important;
  padding: 14px !important;
}

.s360c-card,
.s360c-notice,
.s360c-error {
  border-radius: var(--cp-radius) !important;
  border: 1px solid var(--cp-border) !important;
  background: var(--cp-surface) !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.08) !important;
}

.s360c-notice {
  color: color-mix(in srgb, var(--cp-ok) 72%, var(--cp-text)) !important;
  background: color-mix(in srgb, var(--cp-ok) 12%, var(--cp-surface-strong)) !important;
}

.s360c-error {
  color: #ff453a !important;
  background: color-mix(in srgb, #ff453a 12%, var(--cp-surface-strong)) !important;
}

.s360c-customer-left span,
.s360c-advisor-box p,
.s360c-step-item small,
.s360c-footer,
.s360c-loading {
  color: var(--cp-soft) !important;
}

.s360c-customer-left h2,
.s360c-process-card h2,
.s360c-process-card h3,
.s360c-status-box h4,
.s360c-advisor-box h3 {
  color: var(--cp-text) !important;
  letter-spacing: -0.02em;
}

.s360c-advisor-box,
.s360c-status-box,
.s360c-office-card {
  border: 1px solid var(--cp-border) !important;
  background: var(--cp-surface-strong) !important;
  border-radius: 12px !important;
}

.s360c-step-dot {
  border-color: color-mix(in srgb, var(--cp-accent) 35%, var(--cp-border)) !important;
  color: var(--cp-soft) !important;
}

.s360c-step-dot.is-done {
  border-color: color-mix(in srgb, var(--cp-ok) 65%, var(--cp-border)) !important;
  background: color-mix(in srgb, var(--cp-ok) 24%, var(--cp-surface-strong)) !important;
  color: color-mix(in srgb, var(--cp-ok) 65%, var(--cp-text)) !important;
}

.s360c-btn,
button.s360c-btn,
.s360c-btn-sec {
  min-height: 40px;
  border-radius: 11px !important;
  border: 1px solid var(--cp-border) !important;
  background: var(--cp-surface-strong) !important;
  color: var(--cp-text) !important;
  font-weight: 600 !important;
  transition: transform .16s ease, box-shadow .2s ease, border-color .2s ease, background-color .2s ease !important;
}

.s360c-btn:hover,
button.s360c-btn:hover,
.s360c-btn-sec:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(15,23,42,.14);
}

.s360c-btn:focus,
button.s360c-btn:focus,
.s360c-btn-sec:focus,
#system360-client-portal input:focus,
#system360-client-portal select:focus,
#system360-client-portal textarea:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--cp-accent) 72%, var(--cp-border)) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cp-accent) 20%, transparent) !important;
}

#system360-client-portal input,
#system360-client-portal select,
#system360-client-portal textarea {
  border-radius: 11px !important;
  border: 1px solid var(--cp-border) !important;
  background: var(--cp-surface-strong) !important;
  color: var(--cp-text) !important;
  min-height: 40px;
  padding: 9px 12px;
}

.s360c-pay-file,
.s360c-doc-file {
  border-radius: 10px !important;
  border: 1px dashed color-mix(in srgb, var(--cp-accent) 40%, var(--cp-border)) !important;
  background: color-mix(in srgb, var(--cp-accent-soft) 55%, var(--cp-surface-strong)) !important;
}

@media (max-width: 860px) {
  .s360c-wrap {
    max-width: calc(100vw - 12px);
    padding: 10px !important;
  }
}

/* ===== CLIENT PORTAL LAYOUT RESTRUCTURE V2 ===== */
#system360-client-portal{
  --ps1: 8px;
  --ps2: 12px;
  --ps3: 16px;
  --ps4: 24px;
}

.s360c-wrap{
  margin: var(--ps3) auto !important;
  padding: var(--ps3) !important;
  gap: var(--ps3);
}

.s360c-card{
  padding: var(--ps3) !important;
}

.s360c-card + .s360c-card,
.s360c-card + .s360c-footer,
.s360c-notice + .s360c-card{
  margin-top: var(--ps2) !important;
}

.s360c-customer-strip{
  gap: var(--ps3) !important;
}

.s360c-steps-row{
  gap: var(--ps2) !important;
  margin-bottom: var(--ps3) !important;
}

.s360c-form-grid{
  gap: var(--ps2) !important;
}

.s360c-btn-row{
  gap: var(--ps2) !important;
  margin-top: var(--ps2) !important;
}

.s360c-office-grid{
  gap: var(--ps2) !important;
}

@media (max-width: 860px){
  .s360c-customer-strip{
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px){
  .s360c-wrap{
    margin: var(--ps1) auto !important;
    padding: var(--ps2) !important;
  }
  .s360c-card{
    padding: var(--ps2) !important;
  }
}
