/* Phase 27: Frontend directory UX polish */
:root{
  --directory-blue:#0f4c81;
  --directory-blue-2:#1d6fb8;
  --directory-soft:#eef6ff;
  --directory-line:#dbeafe;
  --directory-text:#1f2937;
  --directory-muted:#64748b;
  --directory-danger:#be123c;
  --directory-danger-bg:#fff1f2;
  --directory-green:#047857;
}
.directory-login-wrap{
  max-width:760px;
  margin:36px auto;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:20px;
  align-items:stretch;
}
.directory-login-card,
.directory-login-note{
  border:1px solid var(--directory-line);
  border-radius:24px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  box-shadow:0 18px 45px rgba(15,76,129,.10);
}
.directory-login-card{padding:30px;}
.directory-login-note{padding:24px;}
.directory-eyebrow{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:7px 12px;
  border-radius:999px;
  background:var(--directory-soft);
  color:var(--directory-blue);
  font-weight:800;
  font-size:14px;
}
.directory-login-card h1{margin:18px 0 8px;font-size:30px;line-height:1.2;}
.directory-login-desc{color:var(--directory-muted);line-height:1.75;margin-bottom:20px;}
.directory-login-form label{font-weight:800;color:var(--directory-text);}
.directory-login-form input{
  width:100%;
  margin-top:8px;
  min-height:50px;
  border-radius:16px;
  border:1px solid #cbd5e1;
  padding:0 15px;
  font-size:18px;
  letter-spacing:.04em;
}
.directory-login-form input:focus{
  outline:none;
  border-color:var(--directory-blue-2);
  box-shadow:0 0 0 4px rgba(29,111,184,.13);
}
.directory-login-form .btn{min-height:50px;border-radius:16px;font-size:16px;font-weight:800;}
.directory-error{
  margin:16px 0;
  padding:13px 14px;
  border-radius:16px;
  background:var(--directory-danger-bg);
  color:var(--directory-danger);
  font-weight:800;
  border:1px solid #fecdd3;
}
.directory-help-list{margin:16px 0 0;padding-left:20px;color:var(--directory-muted);line-height:1.85;}
.directory-help-list strong{color:var(--directory-text);}
.directory-page-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.directory-title-block h1{margin-bottom:6px;}
.directory-session-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:#ecfdf5;
  color:var(--directory-green);
  font-weight:800;
  font-size:14px;
}
.directory-filter-card{
  display:grid;
  grid-template-columns:1.5fr .9fr .9fr auto;
  gap:14px;
  align-items:end;
  margin-bottom:18px;
}
.directory-filter-card input,
.directory-filter-card select{
  min-height:44px;
  border-radius:12px;
}
.directory-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.directory-member-card{
  display:grid;
  grid-template-columns:84px 1fr;
  gap:16px;
  margin:0;
  color:inherit;
  border:1px solid #e5edf7;
  border-radius:22px;
  box-shadow:0 12px 32px rgba(15,76,129,.07);
}
.directory-member-main{min-width:0;}
.directory-member-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:8px;
}
.directory-member-name{font-size:22px;font-weight:900;color:#0f172a;line-height:1.25;}
.directory-real-name{color:var(--directory-muted);font-size:14px;margin-top:3px;}
.directory-role-pill{
  flex:0 0 auto;
  max-width:46%;
  background:#f1f5f9;
  color:#334155;
  border-radius:999px;
  padding:6px 10px;
  font-size:13px;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.directory-info-row{
  display:flex;
  gap:8px;
  align-items:flex-start;
  padding:6px 0;
  border-top:1px solid #f1f5f9;
  line-height:1.55;
}
.directory-info-label{width:74px;flex:0 0 74px;color:var(--directory-muted);font-weight:800;}
.directory-info-value{min-width:0;word-break:break-word;}
.directory-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.directory-action-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:9px 12px;
  border-radius:999px;
  background:var(--directory-soft);
  color:var(--directory-blue);
  text-decoration:none;
  font-weight:900;
  border:1px solid var(--directory-line);
}
.directory-action-btn:hover{text-decoration:none;filter:brightness(.98);}
.directory-action-btn.primary{background:var(--directory-blue);color:#fff;border-color:var(--directory-blue);}
.directory-empty{padding:26px;text-align:center;color:var(--directory-muted);}
.directory-welcome-modal{
  position:fixed;
  inset:0;
  background:rgba(15,23,42,.48);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
  padding:20px;
}
.directory-welcome-card{
  background:#fff;
  border-radius:26px;
  padding:30px;
  max-width:430px;
  width:100%;
  box-shadow:0 24px 70px rgba(15,23,42,.28);
  text-align:center;
}
.directory-welcome-icon{
  width:60px;
  height:60px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#ecfdf5;
  color:var(--directory-green);
  font-size:30px;
  margin-bottom:10px;
}
.directory-detail-hero{
  display:grid;
  grid-template-columns:96px 1fr auto;
  gap:18px;
  align-items:center;
  border-radius:24px;
  border:1px solid #e5edf7;
  box-shadow:0 12px 32px rgba(15,76,129,.07);
}
.directory-detail-section h2{margin-top:0;}
.directory-detail-list .directory-info-row:first-of-type{border-top:0;}
@media (max-width:860px){
  .directory-login-wrap{grid-template-columns:1fr;margin:18px auto;}
  .directory-login-card{padding:24px 20px;}
  .directory-login-note{padding:20px;}
  .directory-filter-card{grid-template-columns:1fr;}
  .directory-grid{grid-template-columns:1fr;}
  .directory-member-card{grid-template-columns:70px 1fr;padding:16px;}
  .directory-member-top{display:block;}
  .directory-role-pill{display:inline-flex;max-width:100%;margin-top:8px;}
  .directory-info-row{display:block;}
  .directory-info-label{width:auto;margin-bottom:2px;}
  .directory-actions .directory-action-btn{flex:1 1 auto;}
  .directory-page-head{align-items:flex-start;}
  .directory-page-head form{width:100%;}
  .directory-page-head form .btn{width:100%;}
  .directory-detail-hero{grid-template-columns:76px 1fr;}
  .directory-detail-hero .directory-actions{grid-column:1 / -1;}
}
@media (max-width:520px){
  .directory-member-card{grid-template-columns:1fr;text-align:left;}
  .directory-member-card .avatar-box{display:flex;justify-content:flex-start;}
  .directory-login-card h1{font-size:26px;}
}


/* Phase 28: directory full-list table layout */
.directory-list-page-head{margin-bottom:18px;}
.directory-list-filter{grid-template-columns:1.6fr .8fr .8fr auto;}
.directory-list-summary{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin:8px 0 12px;
  color:var(--directory-muted);
  font-weight:800;
}
.directory-list-summary a{color:var(--directory-blue);text-decoration:none;font-weight:900;}
.directory-table-card{
  padding:0;
  overflow:hidden;
  border:1px solid #e5edf7;
  box-shadow:0 12px 32px rgba(15,76,129,.07);
}
.directory-table-scroll{width:100%;overflow-x:auto;}
.directory-table{
  width:100%;
  min-width:1180px;
  border-collapse:separate;
  border-spacing:0;
  background:#fff;
}
.directory-table th{
  text-align:left;
  padding:14px 14px;
  font-size:14px;
  color:#334155;
  background:#f8fafc;
  border-bottom:1px solid #e5edf7;
  white-space:nowrap;
}
.directory-table td{
  padding:13px 14px;
  border-bottom:1px solid #eef2f7;
  vertical-align:middle;
  color:#1f2937;
}
.directory-table tbody tr:hover{background:#f8fbff;}
.directory-table tbody tr:last-child td{border-bottom:0;}
.directory-person-cell{display:flex;align-items:center;gap:10px;min-width:170px;}
.directory-list-avatar{
  width:44px;
  height:44px;
  border-radius:50%;
  object-fit:cover;
  flex:0 0 44px;
  border:2px solid #dbeafe;
}
.directory-list-avatar-fallback{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--directory-blue);
  color:#fff;
  font-weight:900;
}
.directory-person-namebox{display:flex;flex-direction:column;min-width:0;}
.directory-person-namebox strong{font-size:16px;color:#0f172a;line-height:1.25;}
.directory-person-namebox span{font-size:13px;color:var(--directory-muted);margin-top:3px;}
.directory-role-list-pill{
  display:inline-flex;
  max-width:180px;
  padding:6px 10px;
  border-radius:999px;
  background:#f1f5f9;
  color:#334155;
  font-weight:900;
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.directory-link-strong{font-weight:900;color:var(--directory-blue);}
.directory-company-cell{display:flex;flex-direction:column;min-width:150px;}
.directory-company-cell small{color:var(--directory-muted);margin-top:3px;}
.directory-address-cell{max-width:230px;}
.directory-address-cell a{display:inline-block;max-width:230px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.directory-list-actions{display:flex;gap:6px;flex-wrap:wrap;min-width:160px;}
.directory-mini-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 10px;
  border-radius:999px;
  background:var(--directory-soft);
  border:1px solid var(--directory-line);
  color:var(--directory-blue);
  text-decoration:none;
  font-size:13px;
  font-weight:900;
  white-space:nowrap;
}
.directory-mini-btn.primary{background:var(--directory-blue);border-color:var(--directory-blue);color:#fff;}
.directory-mini-btn:hover{text-decoration:none;filter:brightness(.98);}
@media (max-width:860px){
  .directory-list-filter{grid-template-columns:1fr;}
  .directory-table{min-width:0;}
  .directory-table thead{display:none;}
  .directory-table,
  .directory-table tbody,
  .directory-table tr,
  .directory-table td{display:block;width:100%;}
  .directory-table tr{
    padding:14px;
    border-bottom:10px solid #f1f5f9;
  }
  .directory-table td{
    display:grid;
    grid-template-columns:92px 1fr;
    gap:10px;
    padding:9px 0;
    border-bottom:1px solid #eef2f7;
  }
  .directory-table td::before{
    content:attr(data-label);
    color:var(--directory-muted);
    font-weight:900;
  }
  .directory-table td:first-child{display:block;}
  .directory-table td:first-child::before{display:none;}
  .directory-person-cell{min-width:0;}
  .directory-address-cell{max-width:none;}
  .directory-address-cell a{max-width:100%;white-space:normal;}
  .directory-list-actions{min-width:0;}
  .directory-mini-btn{flex:1 1 auto;}
}
