:root{--bg:#07140d;--bg2:#0d1f15;--card:rgba(6,18,11,.88);--gold:#d8b75f;--gold2:#a67b25;--white:#fff7df;--muted:rgba(255,255,255,.72);--line:rgba(216,183,95,.28);--danger:#ffdfdf}
*{box-sizing:border-box}
body{margin:0;min-height:100vh;font-family:Inter,Arial,sans-serif;color:var(--white);background:radial-gradient(circle at top left,rgba(216,183,95,.12),transparent 32%),linear-gradient(180deg,#07140d,#041009 70%,#020604)}
a{color:inherit}
.portal-shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:24px 0 60px}
.portal-top{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0 22px}
.portal-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.portal-logo img{width:58px;height:58px;object-fit:contain}
.portal-logo strong{font-family:Georgia,serif;font-size:1.3rem;letter-spacing:.08em;color:#ffe8a6}
.home-link{padding:12px 18px;border:1px solid var(--line);border-radius:999px;text-decoration:none;color:#ffe8a6;background:rgba(255,255,255,.04)}
.portal-hero{border:1px solid var(--line);border-radius:28px;padding:34px;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.015));box-shadow:0 28px 70px rgba(0,0,0,.34);text-align:center}
.portal-hero h1{margin:0;font-family:Georgia,serif;font-size:clamp(2.1rem,5vw,4.4rem);line-height:.95;color:#fff1b8}
.portal-hero p{max-width:760px;margin:16px auto 0;color:var(--muted);font-size:1.05rem;line-height:1.6}
.portal-subtitle{max-width:580px;margin:16px auto 0;text-align:center;text-wrap:balance;font-size:clamp(.95rem,2.4vw,1.08rem);line-height:1.55}
.subtitle-break{display:inline}
@media(max-width:520px){.subtitle-break{display:none}}
.login-card,.portal-card{margin-top:22px;border:1px solid var(--line);border-radius:24px;padding:22px;background:var(--card);box-shadow:0 20px 52px rgba(0,0,0,.28)}
.login-row{display:grid;grid-template-columns:1fr auto;gap:12px;max-width:620px;margin:18px auto 0}
.portal-input,.portal-select,textarea{width:100%;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);border-radius:14px;padding:13px 14px;color:#fff;font-size:1rem;outline:none}
.portal-input::placeholder,textarea::placeholder{color:rgba(255,255,255,.48)}

/* DROPDOWN FIX: readable option text on all browsers */
.portal-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23ffe8a6' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.portal-select option{background:#1a2e1f;color:#fff;padding:8px 12px}
.portal-select option:checked{background:#2a4a30}
select.portal-select{color:#fff}

/* Multi-select styling */
.portal-select[multiple]{min-height:80px;padding:6px;border-radius:14px}
.portal-select[multiple] option{padding:6px 10px;border-radius:8px;margin:2px 0}

.portal-btn{border:0;border-radius:999px;padding:13px 20px;background:linear-gradient(135deg,#e6c36a,#b88a2b);color:#07140d;font-weight:700;letter-spacing:.04em;cursor:pointer;box-shadow:0 12px 26px rgba(184,138,43,.22)}
.portal-btn.secondary{background:rgba(255,255,255,.06);color:#ffe8a6;border:1px solid var(--line);box-shadow:none}
.portal-btn.danger{background:rgba(120,30,30,.35);color:var(--danger);border:1px solid rgba(255,150,150,.28);box-shadow:none}
.hidden{display:none!important}
.role-tabs{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:18px}
.role-pill{border:1px solid var(--line);border-radius:999px;padding:9px 13px;background:rgba(255,255,255,.04);color:#ffe8a6;font-size:.9rem}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.span-3{grid-column:span 3}.span-4{grid-column:span 4}.span-6{grid-column:span 6}.span-8{grid-column:span 8}.span-12{grid-column:span 12}
.section-title{margin:0 0 14px;font-size:1.35rem;color:#ffe8a6;font-family:Georgia,serif}
.field-label{display:block;margin:12px 0 7px;color:rgba(255,255,255,.78);font-size:.9rem}
.mini-note{color:rgba(255,255,255,.62);font-size:.86rem;line-height:1.45}
.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:12px}
.stat{border:1px solid var(--line);border-radius:18px;padding:15px;background:rgba(255,255,255,.045)}
.stat small{display:block;color:rgba(255,255,255,.62);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}
.stat strong{display:block;margin-top:6px;color:#fff1b8;font-size:1.45rem}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;margin-top:10px}
table{width:100%;border-collapse:collapse;min-width:760px}
th,td{text-align:left;padding:12px;border-bottom:1px solid rgba(216,183,95,.16);font-size:.92rem}
th{color:#ffe8a6;background:rgba(255,255,255,.05);white-space:nowrap}
td{color:rgba(255,255,255,.83)}
tr:last-child td{border-bottom:0}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.small-btn{border:1px solid var(--line);background:rgba(255,255,255,.04);color:#ffe8a6;border-radius:999px;padding:7px 10px;cursor:pointer;font-size:.82rem}
.small-btn.edit-btn{border-color:rgba(100,200,140,.4);color:#90eeb0}
.small-btn.delete-btn{border-color:rgba(255,150,150,.28);color:#ffb0b0}
.notice{margin-top:14px;padding:12px 14px;border:1px solid rgba(216,183,95,.22);background:rgba(216,183,95,.08);border-radius:16px;color:rgba(255,255,255,.76);line-height:1.5}
.manager-bar{display:flex;gap:12px;flex-wrap:wrap;align-items:end}
.manager-bar>*{flex:1;min-width:180px}
.login-card .notice strong{color:#ffe8a6}
.rate-input{min-width:120px}

/* Modal */
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-box{background:#0d1f15;border:1px solid var(--line);border-radius:24px;padding:28px;max-width:420px;width:100%;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.modal-box.modal-wide{max-width:680px}

/* Priority/status badges */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.78rem;font-weight:600;white-space:nowrap}
.badge-urgent{background:rgba(255,80,80,.25);color:#ff8888;border:1px solid rgba(255,80,80,.4)}
.badge-high{background:rgba(255,160,60,.2);color:#ffb060;border:1px solid rgba(255,160,60,.35)}
.badge-normal{background:rgba(100,200,140,.15);color:#90eeb0;border:1px solid rgba(100,200,140,.3)}
.badge-low{background:rgba(120,140,200,.15);color:#a0b0ee;border:1px solid rgba(120,140,200,.3)}

/* Responsive */
@media(max-width:1000px){.summary-grid{grid-template-columns:repeat(2,1fr)}.span-3{grid-column:span 6}}
@media(max-width:800px){.portal-shell{width:min(100% - 22px,1180px);padding-top:12px}.portal-top{align-items:flex-start}.portal-logo strong{font-size:1rem}.home-link{padding:10px 12px}.portal-hero{padding:24px 16px;border-radius:22px}.login-row{grid-template-columns:1fr}.grid{display:block}.grid>*{margin-bottom:12px}.portal-card{padding:16px;margin-top:16px}.summary-grid{grid-template-columns:repeat(2,1fr)}.portal-btn{width:100%}.actions .portal-btn,.actions .small-btn{width:auto}table{min-width:680px}.span-3{grid-column:auto}}
@media(max-width:520px){.summary-grid{grid-template-columns:1fr}.role-tabs{display:none}.portal-hero p{font-size:.95rem}}

/* Strong dropdown readability on desktop and mobile */
select,
.portal-select,
.portal-select:focus {
  color: #fff7df !important;
  background-color: #0d1f15 !important;
}
.portal-select option,
select option {
  color: #07140d !important;
  background-color: #fff7df !important;
}
.portal-select option:checked,
select option:checked {
  color: #07140d !important;
  background-color: #d8b75f !important;
}

/* Company progress charts */
.chart-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px}
.chart-box{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.035);padding:16px;min-height:220px}
.chart-box h3{margin:0 0 12px;color:#ffe8a6;font-size:1rem;font-family:Georgia,serif}
.bar-chart{display:grid;gap:10px}
.chart-row{display:grid;grid-template-columns:minmax(120px,180px) 1fr auto;gap:10px;align-items:center}
.chart-label{color:rgba(255,255,255,.8);font-size:.84rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chart-track{height:12px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid rgba(216,183,95,.16)}
.chart-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#8d6a22,#d8b75f,#fff1b8);min-width:3px}
.chart-value{color:#fff1b8;font-size:.82rem;white-space:nowrap;text-align:right}
.inline-rate-input{width:94px;min-width:94px;padding:8px 9px;border-radius:10px;font-size:.86rem;text-align:right}
@media(max-width:900px){.chart-grid{grid-template-columns:1fr}.chart-row{grid-template-columns:1fr}.chart-value{text-align:left}.chart-track{height:14px}}

/* CRM / Client List */
.crm-filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:end;margin-top:14px}
.crm-summary{grid-template-columns:repeat(6,1fr)}
.crm-alerts{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.crm-alert{padding:10px 16px;border-radius:14px;font-size:.88rem;display:flex;align-items:center;gap:8px}
.crm-alert-urgent{background:rgba(255,80,80,.15);border:1px solid rgba(255,80,80,.35);color:#ff8888}
.crm-alert-warn{background:rgba(255,180,60,.12);border:1px solid rgba(255,160,60,.3);color:#ffb060}
.crm-alert-info{background:rgba(100,200,140,.12);border:1px solid rgba(100,200,140,.25);color:#90eeb0}

/* CRM Status badges */
.crm-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.76rem;font-weight:600;white-space:nowrap}
.crm-badge-active{background:rgba(70,180,100,.2);color:#6de094;border:1px solid rgba(70,180,100,.4)}
.crm-badge-past{background:rgba(216,183,95,.18);color:#d8b75f;border:1px solid rgba(216,183,95,.35)}
.crm-badge-warm{background:rgba(255,180,60,.18);color:#ffb060;border:1px solid rgba(255,160,60,.35)}
.crm-badge-cold{background:rgba(120,150,200,.18);color:#a0b8e0;border:1px solid rgba(120,150,200,.35)}
.crm-badge-hot{background:rgba(255,70,50,.2);color:#ff9070;border:1px solid rgba(255,70,50,.4)}
.crm-badge-contacted{background:rgba(160,140,220,.18);color:#bca8ee;border:1px solid rgba(160,140,220,.35)}
.crm-badge-followup{background:rgba(255,220,80,.18);color:#ffd84a;border:1px solid rgba(255,220,80,.35)}
.crm-badge-won{background:rgba(70,200,120,.22);color:#5ef090;border:1px solid rgba(70,200,120,.45)}
.crm-badge-lost{background:rgba(180,60,60,.2);color:#e08080;border:1px solid rgba(180,60,60,.35)}
.crm-badge-dnc{background:rgba(100,100,100,.2);color:#aaa;border:1px solid rgba(100,100,100,.35)}

/* Temperature dots */
.temp-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px}
.temp-cold{background:#7090cc}.temp-warm{background:#f0a030}.temp-hot{background:#e04040}

@media(max-width:1000px){.crm-summary{grid-template-columns:repeat(3,1fr)}.progress-summary{grid-template-columns:repeat(4,1fr)}}
@media(max-width:600px){.crm-summary{grid-template-columns:repeat(2,1fr)}.crm-filter-bar{flex-direction:column}.crm-filter-bar>*{width:100%}.progress-summary{grid-template-columns:repeat(2,1fr)}}


/* Keep portal popups usable on desktop and mobile when forms get tall. */
.modal-overlay{
  overflow-y:auto !important;
  overflow-x:hidden !important;
  align-items:flex-start !important;
  justify-content:center !important;
  padding:clamp(14px,3vw,32px) !important;
}
.modal-box{
  max-height:calc(100vh - 32px) !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  margin:auto 0 !important;
}
.modal-box.modal-wide{
  max-height:calc(100vh - 32px) !important;
}
.modal-box::-webkit-scrollbar{width:8px}
.modal-box::-webkit-scrollbar-track{background:rgba(255,255,255,.06);border-radius:999px}
.modal-box::-webkit-scrollbar-thumb{background:rgba(216,183,95,.75);border-radius:999px}
@media(max-width:700px){
  .modal-overlay{padding:10px !important;}
  .modal-box{max-height:calc(100vh - 20px) !important;padding:18px !important;border-radius:18px !important;}
  .modal-box.modal-wide{max-width:100% !important;width:100% !important;}
}
