/* ============================================================
   RFP SYSTEM STYLESHEET
   hansabu.com - Dark Glassmorphism Theme
   ============================================================ */

/* === DESIGN TOKENS === */
:root{
  --color-rfp:#a855f7;
  --color-rfp-light:#c084fc;
  --color-rfp-dark:#7c3aed;
  --color-rfp-bg:rgba(168,85,247,0.08);
  --color-rfp-border:rgba(168,85,247,0.25);
  --color-rfp-glow:rgba(168,85,247,0.4);
  --input-bg:rgba(255,255,255,0.06);
  --input-border:rgba(255,255,255,0.1);
  --input-focus-border:rgba(168,85,247,0.5);
  --danger:#ef4444;
  --success:#22c55e;
  --warning:#eab308;
  --info:#3b82f6;
}

/* === SHARED: NAVIGATION === */
.rfp-nav{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(1rem,5vw,3rem);
  background:rgba(10,10,15,0.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--card-border);
}
.rfp-nav__brand{
  font-size:1.3rem;font-weight:800;
  letter-spacing:0.12em;
  background:linear-gradient(135deg,#00d2ff,#7f00ff,#f857a6);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  text-decoration:none;
}
.rfp-nav__links{display:flex;gap:1.5rem}
.rfp-nav__links a{
  font-size:0.85rem;color:var(--text-secondary);
  transition:color 0.3s;font-weight:500;
  text-decoration:none;
}
.rfp-nav__links a:hover{color:var(--text-primary)}

/* === SHARED: HERO === */
.rfp-hero{
  position:relative;z-index:1;
  padding:clamp(3rem,8vh,6rem) clamp(1rem,5vw,3rem) clamp(2rem,5vh,4rem);
  text-align:center;
  border-bottom:1px solid var(--card-border);
  background:linear-gradient(135deg,rgba(168,85,247,0.08),rgba(124,58,237,0.04));
}
.rfp-hero__tag{
  display:inline-block;
  font-size:0.7rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:0.25rem 0.8rem;border-radius:9rem;
  margin-bottom:1rem;
  background:rgba(168,85,247,0.15);color:var(--color-rfp);
}
.rfp-hero__title{
  font-size:clamp(1.6rem,4vw,2.4rem);
  font-weight:800;line-height:1.3;
  max-width:700px;margin:0 auto 0.8rem;
}
.rfp-hero__subtitle{
  font-size:0.9rem;color:var(--text-secondary);
  max-width:500px;margin:0 auto;
}

/* === SHARED: CARD === */
.rfp-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:1.2rem;
  padding:clamp(1.2rem,2vw,2rem);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  transition:all 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}
.rfp-card:hover{
  border-color:var(--card-hover-border);
}

/* === SHARED: FOOTER === */
.rfp-footer{
  position:relative;z-index:1;
  text-align:center;
  padding:3vh 2rem 4vh;
  flex-shrink:0;
}
.rfp-footer .footer-text{
  font-size:0.75rem;
  color:var(--text-secondary);
  opacity:0.6;
}
.rfp-footer .footer-links{
  display:flex;
  justify-content:center;
  gap:1.2rem;
  margin-top:0.5rem;
}
.rfp-footer .footer-links a{
  color:var(--text-secondary);
  opacity:0.5;
  transition:opacity 0.3s;
  font-size:0.75rem;
  text-decoration:none;
}
.rfp-footer .footer-links a:hover{opacity:1}


/* ============================================================
   FORM COMPONENTS (Client: /request/)
   ============================================================ */

/* === INVITE GATE === */
.invite-gate{
  position:relative;z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:60vh;
  padding:2rem clamp(1rem,5vw,3rem);
}
.invite-gate__card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:1.2rem;
  padding:2.5rem 2rem;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  text-align:center;
  max-width:420px;
  width:100%;
  animation:fadeInUp 0.6s ease-out both;
}
.invite-gate__icon{
  width:4rem;height:4rem;
  margin:0 auto 1.2rem;
  border-radius:1rem;
  background:linear-gradient(135deg,rgba(168,85,247,0.2),rgba(124,58,237,0.1));
  display:flex;align-items:center;justify-content:center;
  color:var(--color-rfp);
}
.invite-gate__icon svg{width:2rem;height:2rem;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.invite-gate__title{
  font-size:1.4rem;font-weight:700;
  margin-bottom:0.4rem;
}
.invite-gate__subtitle{
  font-size:0.85rem;color:var(--text-secondary);
  margin-bottom:1.5rem;
}
.invite-gate__input-wrap{
  display:flex;gap:0.6rem;
  margin-bottom:0.8rem;
}
.invite-gate__input{
  flex:1;
  background:var(--input-bg);
  border:1px solid var(--input-border);
  border-radius:0.6rem;
  padding:0.7rem 1rem;
  color:var(--text-primary);
  font-family:var(--font-family);
  font-size:0.9rem;
  letter-spacing:0.1em;
  text-align:center;
  outline:none;
  transition:border-color 0.3s,box-shadow 0.3s;
}
.invite-gate__input:focus{
  border-color:var(--input-focus-border);
  box-shadow:0 0 0 3px rgba(168,85,247,0.15);
}
.invite-gate__input::placeholder{
  color:var(--text-secondary);opacity:0.5;
  letter-spacing:0.05em;
}
.invite-gate__error{
  font-size:0.78rem;color:var(--danger);
  min-height:1.2em;
  margin-top:0.3rem;
}

/* === RFP FORM === */
.rfp-form{
  position:relative;z-index:1;
  max-width:720px;
  margin:0 auto;
  padding:2rem clamp(1rem,5vw,3rem) 3rem;
  animation:fadeInUp 0.5s ease-out both;
}

/* === PROGRESS INDICATOR === */
.rfp-progress{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0;
  margin-bottom:2.5rem;
  padding:0 1rem;
}
.rfp-progress__step{
  display:flex;align-items:center;justify-content:center;
  width:2.2rem;height:2.2rem;
  border-radius:50%;
  font-size:0.78rem;font-weight:600;
  border:2px solid var(--card-border);
  background:transparent;
  color:var(--text-secondary);
  transition:all 0.3s;
  flex-shrink:0;
  cursor:pointer;
}
.rfp-progress__step--active{
  border-color:var(--color-rfp);
  background:var(--color-rfp);
  color:#fff;
  box-shadow:0 0 12px rgba(168,85,247,0.4);
}
.rfp-progress__step--completed{
  border-color:var(--success);
  background:rgba(34,197,94,0.15);
  color:var(--success);
}
.rfp-progress__line{
  flex:1;
  height:2px;
  background:var(--card-border);
  max-width:3rem;
  transition:background 0.3s;
}
.rfp-progress__line--completed{
  background:var(--success);
}

/* === FORM SECTIONS === */
.rfp-section{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:1.2rem;
  padding:clamp(1.5rem,2.5vw,2rem);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  margin-bottom:1.5rem;
  animation:sectionFadeIn 0.4s ease-out both;
}
.rfp-section[hidden]{display:none}
.rfp-section__title{
  font-size:1.1rem;font-weight:700;
  margin-bottom:0.3rem;
  padding-left:0.8rem;
  border-left:3px solid var(--color-rfp);
}
.rfp-section__desc{
  font-size:0.8rem;color:var(--text-secondary);
  margin-bottom:1.5rem;
  padding-left:0.8rem;
}

@keyframes sectionFadeIn{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}

/* === FORM FIELD GROUP === */
.rfp-field{
  margin-bottom:1.2rem;
}
.rfp-field:last-child{margin-bottom:0}
.rfp-label{
  display:block;
  font-size:0.82rem;font-weight:600;
  margin-bottom:0.4rem;
  color:var(--text-primary);
}
.rfp-label__required{
  color:var(--color-rfp);
  margin-left:0.15rem;
}
.rfp-label__hint{
  font-weight:400;
  color:var(--text-secondary);
  font-size:0.75rem;
  margin-left:0.3rem;
}

/* === FORM INPUTS === */
.rfp-input,
.rfp-select,
.rfp-textarea{
  width:100%;
  background:var(--input-bg);
  border:1px solid var(--input-border);
  border-radius:0.6rem;
  padding:0.65rem 0.9rem;
  color:var(--text-primary);
  font-family:var(--font-family);
  font-size:0.85rem;
  outline:none;
  transition:border-color 0.3s,box-shadow 0.3s;
  -webkit-appearance:none;
  appearance:none;
}
.rfp-input:focus,
.rfp-select:focus,
.rfp-textarea:focus{
  border-color:var(--input-focus-border);
  box-shadow:0 0 0 3px rgba(168,85,247,0.12);
}
.rfp-input::placeholder,
.rfp-textarea::placeholder{
  color:var(--text-secondary);opacity:0.5;
}
.rfp-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239898a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 0.8rem center;
  padding-right:2.2rem;
  cursor:pointer;
}
.rfp-select option{
  background:var(--bg-secondary);
  color:var(--text-primary);
}
.rfp-textarea{
  min-height:100px;
  resize:vertical;
  line-height:1.6;
}

/* Validation states */
.rfp-input--error,
.rfp-select--error,
.rfp-textarea--error{
  border-color:var(--danger)!important;
  box-shadow:0 0 0 3px rgba(239,68,68,0.12)!important;
}
.rfp-error-msg{
  font-size:0.72rem;
  color:var(--danger);
  margin-top:0.25rem;
  min-height:0;
  opacity:0;
  transition:opacity 0.2s;
}
.rfp-error-msg--visible{
  opacity:1;
}

/* === RADIO & CHECKBOX GROUPS === */
.rfp-radio-group,
.rfp-checkbox-group{
  display:flex;flex-wrap:wrap;gap:0.6rem;
}
.rfp-radio-group--vertical,
.rfp-checkbox-group--vertical{
  flex-direction:column;
}
.rfp-radio,
.rfp-checkbox{
  position:relative;
  display:inline-flex;align-items:center;
  gap:0.5rem;
  padding:0.5rem 0.9rem;
  background:var(--input-bg);
  border:1px solid var(--input-border);
  border-radius:0.6rem;
  cursor:pointer;
  transition:all 0.3s;
  font-size:0.82rem;
  color:var(--text-secondary);
}
.rfp-radio:hover,
.rfp-checkbox:hover{
  border-color:var(--card-hover-border);
  color:var(--text-primary);
}
.rfp-radio input,
.rfp-checkbox input{
  position:absolute;opacity:0;width:0;height:0;
}
.rfp-radio__indicator{
  width:16px;height:16px;
  border-radius:50%;
  border:2px solid var(--input-border);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:all 0.3s;
}
.rfp-radio__indicator::after{
  content:'';width:6px;height:6px;
  border-radius:50%;
  background:var(--color-rfp);
  transform:scale(0);
  transition:transform 0.2s;
}
.rfp-radio input:checked ~ .rfp-radio__indicator{
  border-color:var(--color-rfp);
}
.rfp-radio input:checked ~ .rfp-radio__indicator::after{
  transform:scale(1);
}
.rfp-radio:has(input:checked){
  border-color:var(--color-rfp-border);
  background:var(--color-rfp-bg);
  color:var(--text-primary);
}
.rfp-checkbox__indicator{
  width:16px;height:16px;
  border-radius:4px;
  border:2px solid var(--input-border);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:all 0.3s;
}
.rfp-checkbox__indicator svg{
  width:10px;height:10px;
  stroke:#fff;fill:none;
  stroke-width:3;stroke-linecap:round;stroke-linejoin:round;
  opacity:0;transition:opacity 0.2s;
}
.rfp-checkbox input:checked ~ .rfp-checkbox__indicator{
  background:var(--color-rfp);
  border-color:var(--color-rfp);
}
.rfp-checkbox input:checked ~ .rfp-checkbox__indicator svg{
  opacity:1;
}
.rfp-checkbox:has(input:checked){
  border-color:var(--color-rfp-border);
  background:var(--color-rfp-bg);
  color:var(--text-primary);
}

/* === FILE UPLOAD === */
.rfp-file-upload{
  border:2px dashed var(--input-border);
  border-radius:0.8rem;
  padding:2rem 1.5rem;
  text-align:center;
  cursor:pointer;
  transition:all 0.3s;
  background:transparent;
}
.rfp-file-upload:hover,
.rfp-file-upload--dragover{
  border-color:var(--color-rfp-border);
  background:var(--color-rfp-bg);
}
.rfp-file-upload__icon{
  color:var(--text-secondary);
  margin-bottom:0.6rem;
}
.rfp-file-upload__icon svg{
  width:2rem;height:2rem;
  stroke:currentColor;fill:none;
  stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;
}
.rfp-file-upload__text{
  font-size:0.85rem;color:var(--text-secondary);
  margin-bottom:0.3rem;
}
.rfp-file-upload__hint{
  font-size:0.72rem;color:var(--text-secondary);opacity:0.6;
}
.rfp-file-upload__list{
  margin-top:0.8rem;
  text-align:left;
}
.rfp-file-upload__item{
  display:flex;align-items:center;justify-content:space-between;
  padding:0.4rem 0.6rem;
  background:var(--input-bg);
  border-radius:0.4rem;
  margin-bottom:0.3rem;
  font-size:0.78rem;color:var(--text-secondary);
}
.rfp-file-upload__remove{
  background:none;border:none;
  color:var(--danger);cursor:pointer;
  font-size:0.8rem;padding:0.2rem;
  opacity:0.7;transition:opacity 0.2s;
}
.rfp-file-upload__remove:hover{opacity:1}

/* === DYNAMIC LIST (Reference URLs) === */
.rfp-dynamic-list{
  display:flex;flex-direction:column;gap:0.5rem;
}
.rfp-dynamic-list__row{
  display:flex;gap:0.5rem;align-items:center;
}
.rfp-dynamic-list__row .rfp-input{flex:1}
.rfp-dynamic-list__remove{
  background:none;border:none;
  color:var(--danger);cursor:pointer;
  padding:0.4rem;opacity:0.6;
  transition:opacity 0.2s;
  flex-shrink:0;
}
.rfp-dynamic-list__remove:hover{opacity:1}
.rfp-add-btn{
  display:inline-flex;align-items:center;gap:0.3rem;
  background:none;border:1px dashed var(--input-border);
  border-radius:0.5rem;
  padding:0.4rem 0.8rem;
  color:var(--text-secondary);
  font-size:0.78rem;font-family:var(--font-family);
  cursor:pointer;transition:all 0.3s;
  margin-top:0.3rem;
}
.rfp-add-btn:hover{
  border-color:var(--color-rfp-border);
  color:var(--color-rfp-light);
}

/* === BUTTONS === */
.rfp-btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:0.5rem;
  font-size:0.88rem;font-weight:600;
  font-family:var(--font-family);
  padding:0.7rem 1.8rem;
  border-radius:9rem;
  border:none;cursor:pointer;
  color:#fff;
  background:linear-gradient(135deg,var(--color-rfp),var(--color-rfp-dark));
  transition:all 0.3s;
  text-decoration:none;
}
.rfp-btn:hover{
  transform:scale(1.04);
  filter:brightness(1.15);
  box-shadow:0 4px 20px rgba(168,85,247,0.3);
}
.rfp-btn:active{transform:scale(0.98)}
.rfp-btn:disabled{
  opacity:0.5;cursor:not-allowed;
  transform:none;filter:none;box-shadow:none;
}
.rfp-btn--secondary{
  background:var(--input-bg);
  border:1px solid var(--input-border);
  color:var(--text-secondary);
}
.rfp-btn--secondary:hover{
  border-color:var(--card-hover-border);
  color:var(--text-primary);
  box-shadow:none;filter:none;
}
.rfp-btn--sm{
  font-size:0.78rem;
  padding:0.5rem 1.2rem;
}
.rfp-btn--full{width:100%}

/* Form navigation buttons */
.rfp-form__nav{
  display:flex;justify-content:space-between;
  margin-top:1.5rem;
  gap:1rem;
}

/* === LOADING SPINNER === */
.rfp-spinner{
  display:inline-block;
  width:18px;height:18px;
  border:2px solid rgba(255,255,255,0.3);
  border-top-color:#fff;
  border-radius:50%;
  animation:rfpSpin 0.6s linear infinite;
}
@keyframes rfpSpin{to{transform:rotate(360deg)}}

/* === SUCCESS SCREEN === */
.rfp-success{
  position:relative;z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:60vh;
  padding:2rem;
  text-align:center;
  animation:fadeInUp 0.6s ease-out both;
}
.rfp-success__icon{
  width:5rem;height:5rem;
  margin:0 auto 1.5rem;
  border-radius:50%;
  background:linear-gradient(135deg,rgba(34,197,94,0.2),rgba(34,197,94,0.08));
  display:flex;align-items:center;justify-content:center;
  color:var(--success);
}
.rfp-success__icon svg{
  width:2.5rem;height:2.5rem;
  stroke:currentColor;fill:none;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
}
.rfp-success__title{
  font-size:1.4rem;font-weight:700;
  margin-bottom:0.5rem;
}
.rfp-success__desc{
  font-size:0.9rem;color:var(--text-secondary);
  margin-bottom:2rem;
  line-height:1.6;
}


/* ============================================================
   ADMIN COMPONENTS (/admin/rfp/)
   ============================================================ */

/* === ADMIN LOGIN === */
.admin-login{
  position:relative;z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:80vh;
  padding:2rem;
}
.admin-login__card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:1.2rem;
  padding:2.5rem 2rem;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  text-align:center;
  max-width:380px;width:100%;
  animation:fadeInUp 0.6s ease-out both;
}
.admin-login__title{
  font-size:1.3rem;font-weight:700;
  margin-bottom:0.3rem;
}
.admin-login__subtitle{
  font-size:0.82rem;color:var(--text-secondary);
  margin-bottom:1.5rem;
}
.admin-login__field{
  text-align:left;margin-bottom:1rem;
}
.admin-login__field label{
  display:block;font-size:0.78rem;font-weight:600;
  margin-bottom:0.3rem;color:var(--text-secondary);
}
.admin-login__error{
  font-size:0.78rem;color:var(--danger);
  min-height:1.2em;margin-top:0.5rem;
}

/* === ADMIN LAYOUT === */
.admin-layout{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:240px 1fr;
  min-height:calc(100vh - 60px);
}

/* === ADMIN SIDEBAR === */
.admin-sidebar{
  background:rgba(18,18,26,0.95);
  border-right:1px solid var(--card-border);
  padding:1.5rem 0;
  display:flex;flex-direction:column;
}
.admin-sidebar__header{
  padding:0 1.2rem 1.2rem;
  border-bottom:1px solid var(--card-border);
  margin-bottom:0.8rem;
}
.admin-sidebar__title{
  font-size:0.9rem;font-weight:700;
  color:var(--text-primary);
}
.admin-sidebar__version{
  font-size:0.68rem;color:var(--text-secondary);
  opacity:0.6;
}
.admin-sidebar__nav{
  flex:1;padding:0 0.6rem;
}

/* === ADMIN TAB === */
.admin-tab{
  display:flex;align-items:center;gap:0.6rem;
  width:100%;
  padding:0.65rem 0.8rem;
  border-radius:0.6rem;
  background:transparent;border:none;
  color:var(--text-secondary);
  font-family:var(--font-family);
  font-size:0.82rem;font-weight:500;
  cursor:pointer;transition:all 0.2s;
  text-align:left;
}
.admin-tab:hover{
  background:rgba(255,255,255,0.04);
  color:var(--text-primary);
}
.admin-tab--active{
  background:var(--color-rfp-bg);
  color:var(--color-rfp-light);
  font-weight:600;
}
.admin-tab__icon{
  width:18px;height:18px;flex-shrink:0;
  opacity:0.7;
}
.admin-tab--active .admin-tab__icon{opacity:1}
.admin-tab__badge{
  margin-left:auto;
  background:var(--color-rfp);
  color:#fff;
  font-size:0.65rem;font-weight:700;
  padding:0.1rem 0.45rem;
  border-radius:9rem;
  min-width:18px;text-align:center;
}

/* === ADMIN CONTENT === */
.admin-content{
  padding:1.5rem clamp(1.2rem,3vw,2rem);
  overflow-y:auto;
  max-height:calc(100vh - 60px);
}
.admin-content__header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.5rem;
}
.admin-content__title{
  font-size:1.2rem;font-weight:700;
}

/* === ADMIN STATS === */
.admin-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-bottom:2rem;
}
.admin-stat-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:1rem;
  padding:1.2rem;
  backdrop-filter:blur(8px);
  transition:all 0.3s;
}
.admin-stat-card:hover{border-color:var(--card-hover-border)}
.admin-stat-card__label{
  font-size:0.72rem;color:var(--text-secondary);
  font-weight:500;margin-bottom:0.4rem;
}
.admin-stat-card__value{
  font-size:1.6rem;font-weight:800;
  margin-bottom:0.2rem;
}
.admin-stat-card__change{
  font-size:0.68rem;font-weight:500;
}
.admin-stat-card--purple .admin-stat-card__value{color:var(--color-rfp)}
.admin-stat-card--blue .admin-stat-card__value{color:var(--info)}
.admin-stat-card--green .admin-stat-card__value{color:var(--success)}
.admin-stat-card--yellow .admin-stat-card__value{color:var(--warning)}

/* === ADMIN TABLE === */
.admin-table-wrap{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:1rem;
  overflow:hidden;
  backdrop-filter:blur(8px);
}
.admin-table{
  width:100%;
  border-collapse:collapse;
}
.admin-table th{
  text-align:left;
  padding:0.8rem 1rem;
  font-size:0.72rem;font-weight:600;
  color:var(--text-secondary);
  text-transform:uppercase;
  letter-spacing:0.05em;
  border-bottom:1px solid var(--card-border);
  background:rgba(255,255,255,0.02);
}
.admin-table td{
  padding:0.75rem 1rem;
  font-size:0.82rem;
  color:var(--text-secondary);
  border-bottom:1px solid rgba(255,255,255,0.03);
}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{
  background:rgba(255,255,255,0.02);
}
.admin-table__action{
  background:none;border:none;
  color:var(--color-rfp-light);
  font-family:var(--font-family);
  font-size:0.78rem;font-weight:500;
  cursor:pointer;transition:color 0.2s;
  padding:0.2rem 0.4rem;
}
.admin-table__action:hover{color:var(--color-rfp)}

/* === ADMIN SEARCH === */
.admin-search{
  display:flex;align-items:center;gap:0.8rem;
  margin-bottom:1.2rem;
  flex-wrap:wrap;
}
.admin-search__input{
  flex:1;min-width:200px;
  background:var(--input-bg);
  border:1px solid var(--input-border);
  border-radius:0.6rem;
  padding:0.55rem 0.9rem 0.55rem 2.2rem;
  color:var(--text-primary);
  font-family:var(--font-family);
  font-size:0.82rem;
  outline:none;
  transition:border-color 0.3s,box-shadow 0.3s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239898a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:0.7rem center;
}
.admin-search__input:focus{
  border-color:var(--input-focus-border);
  box-shadow:0 0 0 3px rgba(168,85,247,0.12);
}
.admin-search__filter{
  background:var(--input-bg);
  border:1px solid var(--input-border);
  border-radius:0.6rem;
  padding:0.55rem 2rem 0.55rem 0.8rem;
  color:var(--text-primary);
  font-family:var(--font-family);
  font-size:0.82rem;
  outline:none;
  cursor:pointer;
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239898a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 0.6rem center;
}
.admin-search__filter option{
  background:var(--bg-secondary);
  color:var(--text-primary);
}

/* === ADMIN PAGINATION === */
.admin-pagination{
  display:flex;align-items:center;justify-content:center;
  gap:0.3rem;
  margin-top:1.2rem;
  padding:0.8rem 0;
}
.admin-pagination__btn{
  width:2rem;height:2rem;
  display:flex;align-items:center;justify-content:center;
  border-radius:0.5rem;
  background:transparent;border:1px solid var(--card-border);
  color:var(--text-secondary);
  font-family:var(--font-family);
  font-size:0.78rem;cursor:pointer;
  transition:all 0.2s;
}
.admin-pagination__btn:hover{
  border-color:var(--card-hover-border);
  color:var(--text-primary);
}
.admin-pagination__btn--active{
  border-color:var(--color-rfp);
  background:var(--color-rfp-bg);
  color:var(--color-rfp-light);
  font-weight:600;
}
.admin-pagination__btn:disabled{
  opacity:0.3;cursor:not-allowed;
}

/* === ADMIN MODAL === */
.admin-modal{
  position:fixed;inset:0;z-index:200;
  display:none;
  align-items:center;justify-content:center;
  padding:2rem;
}
.admin-modal--open{display:flex}
.admin-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(0,0,0,0.7);
  backdrop-filter:blur(4px);
}
.admin-modal__content{
  position:relative;
  background:var(--bg-secondary);
  border:1px solid var(--card-border);
  border-radius:1.2rem;
  max-width:800px;width:100%;
  max-height:85vh;
  overflow-y:auto;
  padding:0;
  animation:modalSlideIn 0.3s ease-out;
}
@keyframes modalSlideIn{
  from{opacity:0;transform:translateY(20px) scale(0.97)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.admin-modal__header{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.2rem 1.5rem;
  border-bottom:1px solid var(--card-border);
  position:sticky;top:0;
  background:var(--bg-secondary);
  z-index:1;
  border-radius:1.2rem 1.2rem 0 0;
}
.admin-modal__title{font-size:1rem;font-weight:700}
.admin-modal__close{
  background:none;border:none;
  color:var(--text-secondary);cursor:pointer;
  padding:0.3rem;transition:color 0.2s;
  display:flex;align-items:center;justify-content:center;
}
.admin-modal__close:hover{color:var(--text-primary)}
.admin-modal__close svg{
  width:20px;height:20px;stroke:currentColor;
  fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
}
.admin-modal__body{
  padding:1.5rem;
}
.admin-modal__section{
  margin-bottom:1.5rem;
}
.admin-modal__section-title{
  font-size:0.85rem;font-weight:700;
  padding-left:0.6rem;
  border-left:3px solid var(--color-rfp);
  margin-bottom:0.8rem;
}
.admin-modal__field{
  display:flex;gap:0.3rem;
  margin-bottom:0.5rem;
  font-size:0.82rem;
}
.admin-modal__field-label{
  color:var(--text-secondary);
  min-width:100px;flex-shrink:0;
}
.admin-modal__field-value{
  color:var(--text-primary);
  word-break:break-all;
}
.admin-modal__actions{
  display:flex;align-items:center;gap:0.8rem;
  padding:1rem 1.5rem;
  border-top:1px solid var(--card-border);
}

/* === ADMIN BADGE === */
.admin-badge{
  display:inline-flex;align-items:center;
  font-size:0.68rem;font-weight:600;
  padding:0.15rem 0.6rem;
  border-radius:9rem;
  letter-spacing:0.02em;
}
.admin-badge--new{background:rgba(59,130,246,0.15);color:#60a5fa}
.admin-badge--reviewing{background:rgba(234,179,8,0.15);color:#facc15}
.admin-badge--analyzed{background:rgba(34,197,94,0.15);color:#4ade80}
.admin-badge--quoted{background:rgba(168,85,247,0.15);color:var(--color-rfp-light)}
.admin-badge--contracted{background:rgba(6,182,212,0.15);color:#22d3ee}
.admin-badge--closed{background:rgba(107,114,128,0.15);color:#9ca3af}
.admin-badge--active{background:rgba(34,197,94,0.15);color:#4ade80}
.admin-badge--expired{background:rgba(239,68,68,0.15);color:#f87171}
.admin-badge--used{background:rgba(234,179,8,0.15);color:#facc15}

/* === ADMIN AI RESULT === */
.admin-ai-result{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:0.8rem;
  overflow:hidden;
}
.admin-ai-tabs{
  display:flex;overflow-x:auto;
  border-bottom:1px solid var(--card-border);
  background:rgba(255,255,255,0.02);
}
.admin-ai-tab{
  padding:0.6rem 1rem;
  font-size:0.75rem;font-weight:500;
  color:var(--text-secondary);
  background:none;border:none;
  border-bottom:2px solid transparent;
  cursor:pointer;transition:all 0.2s;
  white-space:nowrap;
  font-family:var(--font-family);
}
.admin-ai-tab:hover{color:var(--text-primary)}
.admin-ai-tab--active{
  color:var(--color-rfp-light);
  border-bottom-color:var(--color-rfp);
}
.admin-ai-panel{
  padding:1.2rem;
  font-size:0.82rem;
  color:var(--text-secondary);
  line-height:1.7;
  display:none;
}
.admin-ai-panel--active{display:block}
.admin-ai-panel h4{
  font-size:0.88rem;font-weight:600;
  color:var(--text-primary);
  margin-bottom:0.5rem;
}
.admin-ai-panel ul{
  margin:0.5rem 0 1rem 1.2rem;
}
.admin-ai-panel li{margin-bottom:0.3rem}

/* === ADMIN INVITE CARD === */
.admin-invite-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:0.8rem;
  padding:1rem 1.2rem;
  display:flex;align-items:center;
  gap:1rem;
  margin-bottom:0.6rem;
  transition:all 0.3s;
}
.admin-invite-card:hover{border-color:var(--card-hover-border)}
.admin-invite-card__code{
  font-family:'Courier New',monospace;
  font-size:0.9rem;font-weight:700;
  color:var(--color-rfp-light);
  letter-spacing:0.05em;
  min-width:120px;
}
.admin-invite-card__info{
  flex:1;
  font-size:0.78rem;color:var(--text-secondary);
}
.admin-invite-card__actions{
  display:flex;gap:0.4rem;
}

/* === ADMIN EMPTY STATE === */
.admin-empty{
  text-align:center;
  padding:3rem 1.5rem;
  color:var(--text-secondary);
}
.admin-empty__icon{
  margin-bottom:1rem;
  opacity:0.3;
}
.admin-empty__icon svg{
  width:3rem;height:3rem;
  stroke:currentColor;fill:none;
  stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;
}
.admin-empty__text{
  font-size:0.88rem;
  margin-bottom:0.3rem;
}
.admin-empty__hint{
  font-size:0.75rem;opacity:0.6;
}

/* === STATUS DROPDOWN === */
.admin-status-select{
  background:var(--input-bg);
  border:1px solid var(--input-border);
  border-radius:0.5rem;
  padding:0.4rem 1.8rem 0.4rem 0.6rem;
  color:var(--text-primary);
  font-family:var(--font-family);
  font-size:0.78rem;
  outline:none;cursor:pointer;
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239898a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 0.5rem center;
}

/* === SETTINGS FORM === */
.admin-settings{
  max-width:420px;
}
.admin-settings .rfp-field{margin-bottom:1.2rem}


/* ============================================================
   ANIMATIONS
   ============================================================ */

@keyframes fadeInUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}

/* Staggered card animations */
.rfp-card:nth-child(1){animation:fadeInUp 0.5s ease-out 0.1s both}
.rfp-card:nth-child(2){animation:fadeInUp 0.5s ease-out 0.2s both}
.rfp-card:nth-child(3){animation:fadeInUp 0.5s ease-out 0.3s both}
.rfp-card:nth-child(4){animation:fadeInUp 0.5s ease-out 0.4s both}


/* ============================================================
   RESPONSIVE
   ============================================================ */

/* Tablet */
@media(max-width:1024px){
  .admin-layout{grid-template-columns:200px 1fr}
  .admin-stats{grid-template-columns:repeat(2,1fr)}
  .admin-table{font-size:0.78rem}
  .admin-table th,.admin-table td{padding:0.6rem 0.8rem}
}

/* Mobile */
@media(max-width:768px){
  .rfp-nav{padding:0.8rem 1rem}
  .rfp-nav__links{gap:1rem}
  .rfp-nav__links a{font-size:0.78rem}

  .rfp-hero{padding:2rem 1rem 1.5rem}
  .rfp-hero__title{font-size:1.4rem}

  .rfp-form{padding:1.5rem 1rem 2rem}

  .rfp-progress{gap:0}
  .rfp-progress__step{width:1.8rem;height:1.8rem;font-size:0.7rem}
  .rfp-progress__line{max-width:2rem}

  .rfp-section{padding:1.2rem}

  .rfp-radio-group,
  .rfp-checkbox-group{flex-direction:column}

  .rfp-form__nav{flex-direction:column}
  .rfp-form__nav .rfp-btn{width:100%}

  /* Admin */
  .admin-layout{
    grid-template-columns:1fr;
    grid-template-rows:auto 1fr;
  }
  .admin-sidebar{
    flex-direction:row;
    overflow-x:auto;
    padding:0.5rem;
    border-right:none;
    border-bottom:1px solid var(--card-border);
  }
  .admin-sidebar__header{display:none}
  .admin-sidebar__nav{
    display:flex;flex-direction:row;
    gap:0.3rem;padding:0;
  }
  .admin-tab{
    white-space:nowrap;
    padding:0.5rem 0.8rem;
    font-size:0.75rem;
  }
  .admin-tab__icon{display:none}

  .admin-stats{grid-template-columns:repeat(2,1fr);gap:0.6rem}
  .admin-stat-card{padding:0.8rem}
  .admin-stat-card__value{font-size:1.2rem}

  .admin-content{padding:1rem;max-height:none}

  .admin-modal__content{
    max-width:100%;
    max-height:90vh;
    margin:1rem;
    border-radius:1rem;
  }

  .admin-search{flex-direction:column}
  .admin-search__input{min-width:100%}

  .admin-invite-card{flex-direction:column;align-items:flex-start;gap:0.5rem}

  .admin-table-wrap{overflow-x:auto}
  .admin-table{min-width:600px}
}

/* Desktop: hide mobile sidebar toggle */
@media(min-width:769px){
  .admin-sidebar-toggle{display:none}
}

/* Utility: hidden */
[hidden]{display:none!important}

/* Utility: visually-hidden for screen readers */
.sr-only{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);border:0;
  white-space:nowrap;
}
