:root{
  --conf-primary:#123a63;
  --conf-primary-dark:#0b2847;
  --conf-muted:#6b7280;
  --conf-card:#ffffff;
  --conf-border:#e5e7eb;
  --conf-success:#18a957;
  --conf-error:#cc0000;
  --conf-soft:#f8fafc;
  --conf-warning:#f59e0b;
}
.conf-dashboard { max-width: 1100px; margin: 24px auto; padding: 0 12px; }
.conf-dashboard-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap;margin-bottom:18px;padding:20px;border:1px solid var(--conf-border);border-radius:18px;background:linear-gradient(135deg,#eef8f6 0%,#ffffff 72%);box-shadow:0 10px 24px rgba(1,86,91,.06)}
.conf-dashboard-header__identity{display:flex;gap:14px;align-items:center}
.conf-avatar{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,#237A3C,#4CB272);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:20px;box-shadow:0 8px 20px rgba(0,124,186,.18)}
.conf-dashboard-header h2{margin:0 0 4px;font-size:28px;line-height:1.2}
.conf-dashboard-sub{margin:0;color:var(--conf-muted)}
.conf-quick-stats{display:flex;gap:12px;flex-wrap:wrap}
.conf-stat{min-width:120px;padding:12px 14px;border:1px solid var(--conf-border);border-radius:14px;background:#fff}
.conf-stat__value{display:block;font-size:22px;font-weight:700;color:#111827}
.conf-stat__label{display:block;margin-top:4px;font-size:12px;color:var(--conf-muted);text-transform:uppercase;letter-spacing:.05em}

.conf-tabs {
  --conf-tab-primary:#01565B;
  --conf-tab-primary-dark:#237A3C;
  --conf-tab-accent:#6EC1E4;
  --conf-tab-accent-strong:#4CB272;
  --conf-tab-bg:#eef8f6;
  --conf-tab-line:#cfe3de;
  display:flex;
  gap:2px;
  margin:12px 0 18px;
  flex-wrap:wrap;
  align-items:flex-end;
  padding:14px 14px 0;
  position:relative;
  border:1px solid var(--conf-tab-line);
  border-bottom:none;
  border-radius:24px 24px 0 0;
  background:linear-gradient(180deg,#f9fbfe 0%, var(--conf-tab-bg) 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85);
}
.conf-tabs::after{
  content:"";
  position:absolute;
  left:14px;
  right:14px;
  bottom:0;
  height:1px;
  background:var(--conf-tab-line);
}
.conf-tab {
  appearance:none;
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:none;
  padding:14px 18px 13px !important;
  background:transparent !important;
  cursor:pointer;
  border-radius:18px 18px 0 0;
  color:#5b6880 !important;
  white-space:nowrap;
  font-weight:700;
  letter-spacing:.01em;
  transition:transform .18s ease, color .18s ease, background .18s ease, box-shadow .18s ease;
}
.conf-tab > *{position:relative;z-index:2}
.conf-tab::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:18px 18px 0 0;
  border:1px solid transparent;
  border-bottom:none;
  transition:border-color .18s ease, background .18s ease;
}
.conf-tab:hover {
  background:rgba(255,255,255,.65) !important;
  color:var(--conf-tab-primary) !important;
  transform:translateY(-1px);
}
.conf-tab.active {
  background:#fff !important;
  font-weight:700;
  color:var(--conf-tab-primary) !important;
  box-shadow:0 -10px 22px rgba(15,23,42,.05), 0 10px 18px rgba(15,23,42,.04);
  z-index:2;
}
.conf-tab.active::before {
  border-color:var(--conf-tab-line);
  background:linear-gradient(180deg,rgba(255,255,255,.98), #fff);
}
.conf-tab.active::after {
  content:"";
  position:absolute;
  left:18px;
  right:18px;
  bottom:-2px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--conf-tab-accent), var(--conf-tab-accent-strong));
}
.conf-tab.active:hover { background:#fff !important; color:var(--conf-tab-primary) !important; }
.conf-tab__icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:inherit;opacity:.95}
.conf-tab__icon svg{width:18px;height:18px;display:block}
.conf-tab__label{position:relative}
.conf-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  margin-left:2px;
  padding:0 7px;
  background:linear-gradient(135deg,var(--conf-tab-accent), var(--conf-tab-accent-strong)) !important;
  color:#fff !important;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  box-shadow:0 8px 16px rgba(232,137,31,.24);
}
@media (max-width: 720px){
  .conf-tabs{
    flex-wrap:nowrap;
    overflow-x:auto;
    padding:0 0 6px;
    border:none;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
  }
  .conf-tabs::after{display:none}
  .conf-tab{
    flex:0 0 auto;
    gap:8px;
    border:1px solid var(--conf-border);
    border-radius:999px;
    padding:10px 14px !important;
    background:#f9fafb !important;
    color:#111 !important;
  }
  .conf-tab::before,.conf-tab::after{display:none}
  .conf-tab.active{
    background:linear-gradient(135deg,var(--conf-tab-primary), var(--conf-tab-primary-dark)) !important;
    color:#fff !important;
    box-shadow:0 10px 22px rgba(18,58,99,.20);
    border-color:transparent;
  }
  .conf-tab__icon{width:16px;height:16px}
  .conf-tab__icon svg{width:16px;height:16px}
  .conf-tab .conf-badge{
    background:rgba(255,255,255,.18) !important;
    color:#fff !important;
    box-shadow:none;
  }
}

.conf-tab-panel { display:none; }
.conf-tab-panel.active { display:block; animation:confPanelIn .22s ease; }
@keyframes confPanelIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.conf-grid.two-up { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:16px; }
@media (max-width: 720px){ .conf-grid.two-up { grid-template-columns: 1fr; } }

.conf-card { position:relative;border:1px solid var(--conf-border); padding:14px; background:var(--conf-card); border-radius:18px; overflow:hidden; }
.conf-card.fancy { box-shadow: 0 10px 26px rgba(0,0,0,0.05) !important; }
.conf-thumb { width: 100%; height: 220px !important; border-radius: 12px !important; margin-bottom:10px; object-fit:cover; }
.conf-card h3{margin:0 0 10px;font-size:21px;line-height:1.3;padding-right:120px}
.conf-card__pill{position:absolute;top:14px;right:14px;z-index:2;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.02em;background:#ecfeff;color:#155e75;border:1px solid #bae6fd}
.conf-pill-open{background:#ecfdf5;border-color:#bbf7d0;color:#166534}
.conf-pill-soon{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.conf-pill-closed{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.conf-deadline-wrap{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:4px 0 12px}
.conf-deadline { color:#374151; font-size:14px !important; font-weight:600; }
.conf-countdown{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#f8fafc;border:1px solid var(--conf-border);border-radius:999px;font-size:12px;color:#475569}
.conf-excerpt.classic p { margin: 0 0 10px; line-height:1.6; font-size:14px; color:#374151; }
.classic p { margin: 0 0 10px; line-height:1.5; }

.conf-card__field{display:flex;flex-direction:column;gap:6px;margin:14px 0 10px}
.conf-card__field label{font-size:13px;font-weight:600;color:#374151}
.conf-inline-success{ color:#fff; background:var(--conf-success); padding:8px 10px; border-radius:10px; display:inline-block; margin-top:8px; }
.conf-inline-error{ color:#fff; background:var(--conf-error); padding:8px 10px; border-radius:10px; display:inline-block; margin-top:8px; }
.conf-actions { margin-top:10px; display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.conf-muted { color:var(--conf-muted); }

.conf-list { list-style:none; padding-left:0; }
.conf-list li { padding:12px; border:1px solid var(--conf-border); border-radius:12px; margin-bottom:10px; background:#fff !important; }
.conf-list li.is-unread { border-color:#fde68a !important; background:#fffbeb !important; }
.conf-link { color:var(--conf-primary); text-decoration:none; background:none; border:none; padding:0; cursor:pointer; }

.conf-alert { padding:12px 14px; background:#fff7e6 !important; border:1px solid #ffe8b3 !important; margin-bottom:14px; border-radius:12px; }

.conf-auth-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:24px; max-width:980px; margin: 24px auto; }
@media (max-width: 720px){ .conf-auth-grid{ grid-template-columns: 1fr; } }
.conf-auth-col{ border:1px solid var(--conf-border); background:#fff !important; padding:20px; border-radius:18px; box-shadow:0 10px 24px rgba(15,23,42,.05) }
.conf-auth-col h3{margin-top:0;margin-bottom:16px;font-size:24px}
.conf-auth-form p{margin:0 0 12px}
.conf-auth-form label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}
.conf-auth-form input:not([type="checkbox"]), .conf-auth-form select{width:100%;padding:12px 14px;border:1px solid var(--conf-border);border-radius:12px;background:#fff !important;box-sizing:border-box}
.conf-auth-form .button{width:100%;border-radius:12px;padding:12px 16px}
.conf-auth-helper{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-top:6px;flex-wrap:wrap}
.conf-auth-helper label{margin:0;display:flex;align-items:center;gap:8px;font-weight:500}
.conf-login-wrap .conf-msg, .conf-register-form .conf-msg, .conf-otp-form .conf-msg { margin-top:8px; min-height:20px; color:var(--conf-primary); }
.conf-password-meter{height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden;margin-top:8px}
.conf-password-meter span{display:block;height:100%;width:0;background:#ef4444;transition:width .2s ease}
.conf-password-hint{display:block;margin-top:8px;color:var(--conf-muted);font-size:12px}
.conf-auth-transition{transition:opacity .28s ease, transform .28s ease, max-height .35s ease;max-height:980px;opacity:1;transform:translateY(0);overflow:visible}
.conf-auth-transition.is-hidden{max-height:0;opacity:0;transform:translateY(8px);pointer-events:none;margin:0;padding-top:0;padding-bottom:0}
.conf-forgot-inline{ margin-top:10px; }

.conf-mini{ display:flex; align-items:flex-start; gap:12px; }
.conf-mini__thumb{width:64px;height:64px;object-fit:cover;border-radius:10px;flex:0 0 64px}
.conf-mini__meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;font-size:12px;color:#4b5563}
.conf-mini__meta span{padding:5px 8px;border-radius:999px;background:#f8fafc;border:1px solid var(--conf-border)}
.conf-mini__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

.conf-assets-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
@media (max-width:720px){.conf-assets-grid{grid-template-columns:1fr}}
.conf-asset-card{display:flex;gap:14px;align-items:flex-start;padding:16px;border:1px solid var(--conf-border);border-radius:18px;background:#fff;box-shadow:0 8px 20px rgba(15,23,42,.04)}
.conf-asset-card__icon{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;background:#eff6ff;flex:0 0 46px}
.conf-asset-card__body{flex:1}
.conf-asset-card__title{margin:0 0 6px;font-size:18px;line-height:1.3}
.conf-asset-card__meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.conf-asset-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:600;background:#f8fafc;border:1px solid var(--conf-border);color:#334155}
.conf-asset-badge.is-revoked{background:#fef2f2;border-color:#fecaca;color:#991b1b;position:relative;cursor:help}
.conf-asset-badge.is-revoked[title]{text-decoration-style:dotted}
.conf-download-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:12px;background:var(--conf-primary);color:#fff !important;text-decoration:none;font-weight:600}
.conf-download-btn:hover{filter:brightness(1.05)}

.conf-note-group{margin-bottom:18px}
.conf-note-group h4{margin:0 0 10px;font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:#64748b}
.conf-note-row{display:flex;gap:12px;align-items:flex-start}
.conf-note-icon{width:38px;height:38px;border-radius:12px;background:#f8fafc;border:1px solid var(--conf-border);display:flex;align-items:center;justify-content:center;flex:0 0 38px}
.conf-note-body{flex:1}
.conf-note-time{display:block;margin-top:6px;font-size:12px;color:var(--conf-muted)}

/* Modal */
.conf-modal { position:fixed; inset:0; display:none; z-index:9999; }
.conf-modal.open { display:block; }
.conf-modal__overlay { position:absolute; inset:0; background:rgba(0,0,0,.45) !important; }
.conf-modal__content {
  position:relative; max-width:780px; margin:40px auto; background:#fff !important; border-radius:18px;
  padding:20px; box-shadow:0 12px 32px rgba(0,0,0,.25);
}
.conf-modal__close {
  position:absolute; top:8px; right:10px; border:none; background:#fff !important; color:#333 !important; font-size:20px; line-height:1; cursor:pointer;
  width:32px; height:32px; border-radius:999px; box-shadow:0 2px 6px rgba(0,0,0,.1);
}
#conf-modal-img { width:100%; height:300px; object-fit: cover; border-radius:12px; margin:8px 0 10px; }

.conf-actions .button {
  border-radius:999px;
  padding:8px 14px;
  border:1px solid var(--conf-border);
  background:#fff !important;
  color:#111 !important;
  transition: all .18s ease-in-out;
  box-shadow: 0 1px 2px rgba(0,0,0,.04) !important;
}
.conf-actions .button:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0,0,0,.08) !important;
  background:#344454 !important;
  color:#fff !important;
}
.conf-actions .button-primary, .conf-auth-form .button-primary, .button.conf-download-btn {
  background: var(--conf-primary) !important;
  
  color:#fff !important;
  border-color: transparent;
}
.conf-actions .button-primary:hover, .conf-auth-form .button-primary:hover { filter: brightness(1.05); }

.conf-cat-select {
  padding:10px 12px;
  border:1px solid var(--conf-border);
  border-radius:12px;
  background:#fff !important;
  width:100%;
}


/* Header widget */
.conf-header-widget{position:relative;display:inline-flex;align-items:center;justify-content:center}
.conf-header-widget--guest{min-height:48px;padding:6px 14px 6px 6px;border-radius:999px;background:#05673A;color:#fff !important;box-shadow:0 14px 26px rgba(5,103,58,.24) !important;transition:transform .18s ease, box-shadow .18s ease;text-decoration:none;gap:10px}
.conf-header-widget--guest:hover{transform:translateY(-1px);box-shadow:0 18px 32px rgba(5,103,58,.3)}
.conf-header-widget__guest-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:rgba(255,255,255,.12);flex:0 0 36px}
.conf-header-widget__guest-icon svg{width:20px;height:20px;display:block}
.conf-header-widget__guest-label{font-size:14px;font-weight:800;letter-spacing:.01em;white-space:nowrap}
.conf-header-widget__toggle{display:flex;align-items:center;gap:12px;padding:8px 12px 8px 8px;border:1px solid rgba(148,163,184,.28);border-radius:999px;background:rgba(255,255,255,.92);box-shadow:0 14px 28px rgba(15,23,42,.10);cursor:pointer;backdrop-filter:blur(10px);transition:transform .18s ease, box-shadow .18s ease}
.conf-header-widget__toggle:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(15,23,42,.14)}
.conf-header-widget__avatar{width:40px;height:40px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--conf-primary),var(--conf-primary-dark));box-shadow:0 10px 22px rgba(35,122,60,.28);color:#fff;font-weight:800;font-size:16px;flex:0 0 40px}
.conf-header-widget__copy{display:flex;flex-direction:column;min-width:0;text-align:left}
.conf-header-widget__eyebrow{font-size:11px;line-height:1.1;color:#64748b;text-transform:uppercase;letter-spacing:.08em}
.conf-header-widget__name{font-size:14px;font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}
.conf-header-widget__caret{font-size:14px;color:#64748b;transition:transform .18s ease}
.conf-header-widget.is-open .conf-header-widget__caret{transform:rotate(180deg)}
.conf-header-widget__menu{position:absolute;top:calc(100% + 10px);right:0;min-width:230px;padding:10px;background:#fff;border:1px solid rgba(148,163,184,.24);border-radius:18px;box-shadow:0 22px 44px rgba(15,23,42,.16);display:none;z-index:99}
.conf-header-widget.is-open .conf-header-widget__menu{display:block;animation:confMenuIn .16s ease}
.conf-header-widget__menu a{display:flex;align-items:center;padding:11px 12px;border-radius:12px;text-decoration:none;color:#0f172a;font-weight:600}
.conf-header-widget__menu a:hover{background:#f8fafc}
@keyframes confMenuIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* Enhanced modal */
body.conf-modal-open{overflow:hidden}
.conf-modal__content{max-width:920px;margin:32px auto;overflow:hidden;padding:0}
.conf-modal__hero{display:grid;grid-template-columns:minmax(280px, 42%) 1fr;min-height:320px;background:linear-gradient(135deg,#eff6ff 0%,#ffffff 55%,#f8fafc 100%)}
.conf-modal__media{position:relative;min-height:320px;background:linear-gradient(135deg,#dbeafe,#eff6ff);overflow:hidden}
.conf-modal__media img{width:100%;height:100%;object-fit:cover;display:block}
.conf-modal__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:88px;font-weight:800;color:#1d4ed8;background:radial-gradient(circle at top left,#ffffff,#dbeafe)}
.conf-modal__hero-copy{padding:36px 34px 26px;display:flex;flex-direction:column;justify-content:center}
.conf-modal__eyebrow{display:inline-flex;align-self:flex-start;padding:6px 10px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.conf-modal__hero-copy h3{margin:14px 0 12px;font-size:32px;line-height:1.15;color:#0f172a}
.conf-modal__meta{display:flex;flex-wrap:wrap;gap:8px}
.conf-modal__chip{display:inline-flex;align-items:center;padding:8px 10px;border-radius:999px;background:#fff;border:1px solid var(--conf-border);font-size:13px;font-weight:600;color:#334155}
.conf-modal__body{padding:30px 34px 16px;color:#334155;font-size:15px;line-height:1.8}
.conf-modal__footer{padding:0 34px 30px;display:flex;gap:12px;flex-wrap:wrap}
.conf-modal__footer .button{border-radius:12px;padding:12px 16px}

/* Dashboard responsiveness & engagement */
.conf-dashboard{position:relative}
.conf-card,.conf-asset-card,.conf-auth-col,.conf-stat,.conf-mini{transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.conf-card:hover,.conf-asset-card:hover,.conf-mini:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(15,23,42,.08)}
.conf-dashboard-header{gap:18px}
.conf-dashboard-sub{max-width:60ch}
.conf-mini{padding:16px;border-radius:16px;background:#fff}
.conf-mini > div{flex:1;min-width:0}
.conf-mini strong{display:block;font-size:17px;color:#0f172a;margin-bottom:4px}
.conf-mini__actions .conf-link{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#f8fafc;border:1px solid var(--conf-border);text-decoration:none}
.conf-mini__actions .conf-link:hover{background:#eef2ff}
.conf-actions{align-items:stretch}
.conf-actions .button,.conf-download-btn{min-height:44px}

@media (max-width: 1024px){
  .conf-dashboard-header{padding:22px}
  .conf-dashboard-header h2{font-size:24px}
  .conf-modal__hero{grid-template-columns:1fr}
  .conf-modal__media{min-height:240px}
}
@media (max-width: 720px){
  .conf-dashboard{padding-bottom:12px}
  .conf-dashboard-header{padding:18px;border-radius:18px}
  .conf-dashboard-header__identity{align-items:flex-start}
  .conf-avatar{width:101px;height:46px;font-size:18px; border-radius:100px}
  .conf-dashboard-header h2{font-size:22px}
  .conf-quick-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%}
  .conf-stat{min-width:0}
  .conf-card{padding:12px;border-radius:16px}
  .conf-card h3{padding-right:0;font-size:19px}
  .conf-thumb{height:190px !important}
  .conf-actions,.conf-mini__actions{display:grid;grid-template-columns:1fr;gap:10px}
  .conf-actions .button,.conf-download-btn,.conf-mini__actions .conf-link{width:100%;justify-content:center}
  .conf-assets-grid{gap:12px}
  .conf-asset-card{padding:14px;border-radius:16px}
  .conf-auth-col{padding:16px}
  .conf-modal__content{margin:14px;max-height:calc(100vh - 28px);overflow:auto}
  .conf-modal__hero-copy{padding:22px 18px 18px}
  .conf-modal__hero-copy h3{font-size:26px}
  .conf-modal__body{padding:20px 18px 12px}
  .conf-modal__footer{padding:0 18px 22px}
  .conf-header-widget__toggle{padding:7px 10px 7px 7px;gap:10px}
  .conf-header-widget__name{max-width:130px}
}
@media (max-width: 480px){
  .conf-quick-stats{grid-template-columns:1fr}
  .conf-header-widget__copy{display:none}
  .conf-header-widget__toggle{padding:6px;border-radius:999px}
  .conf-header-widget__caret{display:none}
  .conf-header-widget--guest{padding:6px}
  .conf-header-widget__guest-label{display:none}
}


/* Auth tabs / theme alignment */
.conf-dashboard-header h2,
.conf-auth-title,
.conf-card h3,
.conf-asset-card__title,
#conf-modal-title{color:var(--conf-tab-primary)}
.conf-auth-kicker{display:inline-flex;align-items:center;gap:8px;margin-bottom:10px;padding:6px 10px;border-radius:999px;background:rgba(243,170,60,.12);color:var(--conf-tab-accent-strong);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.conf-auth-title{margin:0 0 8px;font-size:30px;line-height:1.15}
.conf-auth-intro{margin:0 0 18px;color:var(--conf-muted);max-width:56ch}
.conf-auth-shell{max-width:980px;margin:24px auto}
.conf-auth-switch{display:inline-flex;gap:6px;align-items:center;padding:8px;background:#fff;border:1px solid var(--conf-border);border-radius:999px;box-shadow:0 12px 28px rgba(15,23,42,.06);margin:0 0 18px}
.conf-auth-switch__btn{appearance:none;border:none;background:transparent;color:#5b6880;padding:12px 18px;border-radius:999px;font-weight:800;cursor:pointer;transition:all .18s ease}
.conf-auth-switch__btn:hover{color:var(--conf-tab-primary);background:#f8fafc}
.conf-auth-switch__btn.is-active{background:linear-gradient(135deg,var(--conf-tab-primary),var(--conf-tab-primary-dark));color:#fff;box-shadow:0 12px 24px rgba(18,58,99,.16)}
.conf-auth-panels{position:relative}
.conf-auth-pane{display:none}
.conf-auth-pane.is-active{display:block;animation:confPanelIn .22s ease}
.conf-auth-form .conf-msg{color:var(--conf-tab-primary)}
.conf-password-wrap{position:relative;display:block}
.conf-password-wrap input{padding-right:52px !important}
.conf-password-toggle{position:absolute;top:40%;right:10px;transform:translateY(-50%);width:43px;height:36px;border:none;border-radius:999px;background:#f8fafc;color:#64748b;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s ease}
.conf-password-toggle:hover{background:#eef2ff;color:var(--conf-tab-primary)}
.conf-password-toggle.is-active{background:rgba(243,170,60,.14);color:var(--conf-tab-accent-strong)}
.conf-password-toggle svg{width:18px;height:18px;display:block}
.conf-otp-actions{display:flex;gap:10px;flex-wrap:wrap}
.conf-otp-form h4{margin:4px 0 8px;color:var(--conf-tab-primary);font-size:24px}
.conf-dashboard-header h2 span,.conf-dashboard-header strong{color:inherit}
.conf-dashboard-header h2{color:var(--conf-tab-primary)}
.conf-auth-col h3{color:var(--conf-tab-primary)}
.conf-card h3{color:var(--conf-tab-primary)}
.conf-card h3 a{color:inherit}
.conf-tab.active::after,.conf-badge{background:linear-gradient(90deg,var(--conf-tab-accent),var(--conf-tab-accent-strong))}
.conf-header-widget__eyebrow{color:var(--conf-tab-accent-strong)}
.conf-header-widget__name{color:var(--conf-tab-primary)}
@media (max-width:720px){
  .conf-auth-switch{display:flex;width:100%;justify-content:stretch}
  .conf-auth-switch__btn{flex:1;text-align:center}
  .conf-auth-shell{margin:18px auto}
  .conf-auth-title{font-size:26px}
  .conf-otp-actions{display:grid;grid-template-columns:1fr;gap:10px}
}


/* Auth recovery and refined theme colors */
.conf-dashboard-header h2,
.conf-auth-title,
.conf-card h3,
.conf-asset-card__title,
#conf-modal-title{color:#01565B}
.conf-auth-kicker{background:rgba(110,193,228,.18);color:#01565B}
.conf-auth-switch__btn:hover{color:#01565B;background:#f2fbfb}
.conf-auth-switch__btn.is-active{background:linear-gradient(135deg,#01565B,#237A3C);color:#fff;box-shadow:0 12px 24px rgba(1,86,91,.18)}
.conf-password-toggle:hover{background:#eff9f3;color:#237A3C}
.conf-password-toggle.is-active{background:rgba(76,178,114,.16);color:#237A3C}
.conf-auth-shell--utility{max-width:760px}
.conf-auth-utility-nav{margin:0 0 16px}
.conf-auth-pane--utility{display:block}
.conf-auth-backlink{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;border:1px solid var(--conf-border);background:#fff;color:#01565B;text-decoration:none;font-weight:700;box-shadow:0 10px 22px rgba(1,86,91,.06)}
.conf-auth-backlink:hover{background:#f4fbfb}
.conf-auth-backline{margin:18px 0 0;color:var(--conf-muted)}
.conf-auth-backline a{color:#237A3C;font-weight:700;text-decoration:none}
.conf-auth-backline a:hover{text-decoration:underline}
.conf-alert--error{background:#fff4f4 !important;border-color:#f5c6cb !important;color:#8a1f2d}
.conf-header-widget__eyebrow{color:#4CB272}
.conf-header-widget__name{color:#01565B}
.conf-card h3{color:#01565B}
.conf-auth-form .button-primary,.button.conf-download-btn{background:linear-gradient(135deg,#237A3C,#05673A) !important}
.conf-auth-form .button-primary:hover,.button.conf-download-btn:hover{filter:brightness(1.03)}
@media (max-width: 720px){
  .conf-auth-shell--utility{margin:18px auto}
}
/* Header widget avatar - logged-in state */
.conf-header-widget__avatar{
  background: linear-gradient(135deg, #237A3C, #4CB272) !important;
  box-shadow: 0 10px 22px rgba(35, 122, 60, 0.28) !important;
  color: #ffffff !important;
}

/* Optional: keep the guest icon aligned with your requested green too */
.conf-header-widget--guest{
  background: linear-gradient(135deg, #05673A, #237A3C) !important;
  box-shadow: 0 14px 26px rgba(5, 103, 58, 0.24) !important;
}

.conf-header-widget--guest:hover{
  box-shadow: 0 18px 32px rgba(5, 103, 58, 0.30) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   NEW FIELDS — REGISTRATION FORM
══════════════════════════════════════════════════════════════════════════════ */

.conf-auth-form select {
  width: 100%;
  padding: 9px 12px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  color: #1f2937;
  background: #fff;
  appearance: auto;
  cursor: pointer;
  transition: border-color .18s;
}
.conf-auth-form select:focus { border-color: #123a63; outline: none; }

.conf-required { color: #dc2626; font-size: 12px; margin-left: 2px; }
.conf-section-header { margin-bottom: 20px; }
.conf-section-header h3 { margin: 0 0 6px; font-size: 18px; color: #111827; }
.conf-section-desc { margin: 0; color: #6b7280; font-size: 14px; }

/* ══════════════════════════════════════════════════════════════════════════════
   BADGES & PILLS
══════════════════════════════════════════════════════════════════════════════ */

.conf-cat-pill {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
  margin-left: 6px;
}

.conf-abs-status-badge, .conf-badge-pending, .conf-badge-approved, .conf-badge-rejected {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
}
.conf-badge-pending  { background: #fef3c7; color: #92400e; }
.conf-badge-approved { background: #d1fae5; color: #065f46; }
.conf-badge-rejected { background: #fee2e2; color: #991b1b; }

/* ══════════════════════════════════════════════════════════════════════════════
   ABSTRACT CARD
══════════════════════════════════════════════════════════════════════════════ */

.conf-abstract-card {
  background: #fff;
  border: 1.5px solid #e5e7eb;
  border-radius: 14px;
  padding: 22px 24px;
  margin-bottom: 22px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}

.conf-abstract-card__header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid #f1f5f9;
}

.conf-abstract-card__conf {
  font-size: 16px;
  color: #111827;
}

.conf-abstract-form { margin-top: 8px; }
.conf-abstract-form p { margin-bottom: 14px; }
.conf-abstract-form label {
  display: block;
  margin-bottom: 5px;
  font-size: 13px;
  font-weight: 600;
  color: #374151;
}

.conf-abstract-textarea {
  width: 100%;
  min-height: 160px;
  padding: 10px 12px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  font-family: inherit;
  resize: vertical;
  transition: border-color .18s;
  box-sizing: border-box;
}
.conf-abstract-textarea:focus { border-color: #123a63; outline: none; }

.conf-word-count {
  font-size: 12px;
  color: #6b7280;
  margin-top: 4px;
  min-height: 18px;
}

.conf-field-group { margin-bottom: 16px; }
.conf-field-group label {
  display: block;
  margin-bottom: 5px;
  font-size: 13px;
  font-weight: 600;
  color: #374151;
}

.conf-file-input {
  display: block;
  margin-top: 6px;
  font-size: 13px;
}

.conf-existing-file {
  margin: 6px 0 0;
  font-size: 13px;
  color: #6b7280;
}
.conf-existing-file a { color: #1d4ed8; text-decoration: none; }
.conf-existing-file a:hover { text-decoration: underline; }

/* ── Upload progress bar ── */
.conf-upload-progress {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}
.conf-upload-progress.is-hidden { display: none; }
.conf-upload-bar {
  flex: 1;
  height: 6px;
  background: #e5e7eb;
  border-radius: 99px;
  overflow: hidden;
}
.conf-upload-bar span {
  display: block;
  height: 100%;
  background: #123a63;
  border-radius: 99px;
  width: 60%;
  animation: conf-bar-pulse 1.2s ease-in-out infinite;
}
@keyframes conf-bar-pulse {
  0%,100% { opacity:.5; transform:scaleX(.7); }
  50%      { opacity:1;  transform:scaleX(1);  }
}
.conf-upload-label { font-size: 12px; color: #6b7280; white-space: nowrap; }

/* ── Co-authors ── */
.conf-coauthor-section { margin: 16px 0; }
.conf-coauthor-section > label { font-size: 14px; font-weight: 600; color: #374151; margin-bottom: 10px; display: block; }
.conf-coauthor-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }

.conf-coauthor-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 8px;
  align-items: center;
  background: #f8fafc;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
}
@media (max-width: 640px) {
  .conf-coauthor-row { grid-template-columns: 1fr; }
}
.conf-coauthor-row input {
  padding: 7px 10px;
  border: 1.5px solid #d1d5db;
  border-radius: 6px;
  font-size: 13px;
  transition: border-color .18s;
}
.conf-coauthor-row input:focus { border-color: #123a63; outline: none; }

.conf-remove-coauthor {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  color: #9ca3af;
  padding: 4px 6px;
  border-radius: 4px;
  transition: color .15s, background .15s;
}
.conf-remove-coauthor:hover { color: #dc2626; background: #fee2e2; }

.conf-add-coauthor {
  font-size: 13px !important;
  padding: 6px 14px !important;
}

/* ── Form footer ── */
.conf-form-footer {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid #f1f5f9;
  flex-wrap: wrap;
}

/* ── Full paper section ── */
.conf-full-paper-section {
  margin-top: 22px;
  padding-top: 20px;
  border-top: 2px dashed #a7f3d0;
  background: #f0fdf4;
  border-radius: 0 0 12px 12px;
  padding: 18px 20px;
}
.conf-full-paper-section h4 {
  margin: 0 0 12px;
  font-size: 15px;
  color: #065f46;
}

/* ── Alert variants ── */
.conf-alert--success {
  background: #f0fdf4;
  border-color: #86efac;
  color: #065f46;
}
.conf-alert--error {
  background: #fef2f2;
  border-color: #fca5a5;
  color: #991b1b;
}
.conf-alert--info {
  background: #eff6ff;
  border-color: #93c5fd;
  color: #1e40af;
}

/* ── Inline success / error ── */
.conf-inline-success {
  padding: 8px 12px;
  background: #f0fdf4;
  border: 1px solid #86efac;
  border-radius: 6px;
  color: #065f46;
  font-size: 13px;
  font-weight: 600;
}
.conf-inline-error {
  padding: 8px 12px;
  background: #fef2f2;
  border: 1px solid #fca5a5;
  border-radius: 6px;
  color: #991b1b;
  font-size: 13px;
  font-weight: 600;
}

/* ── Loading spinner ── */
.conf-loading-spinner {
  width: 36px;
  height: 36px;
  border: 3px solid #e5e7eb;
  border-top-color: #123a63;
  border-radius: 50%;
  animation: conf-spin .7s linear infinite;
  margin: 32px auto;
}
@keyframes conf-spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════════════════════════════════════════
   FEE RECEIPT TAB
══════════════════════════════════════════════════════════════════════════════ */

.conf-fee-card {
  background: #fff;
  border: 1.5px solid #e5e7eb;
  border-radius: 14px;
  padding: 20px 22px;
  margin-bottom: 20px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}

.conf-fee-card__header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid #f1f5f9;
}

.conf-fee-status-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
}
.conf-fee-status-pill--pending  { background: #fef3c7; color: #92400e; }
.conf-fee-status-pill--accepted { background: #d1fae5; color: #065f46; }
.conf-fee-status-pill--rejected { background: #fee2e2; color: #991b1b; }

.conf-fee-instructions {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
  padding: 12px 14px;
  font-size: 13px;
  color: #1e40af;
  margin-bottom: 14px;
}
.conf-fee-instructions strong { display: block; margin-bottom: 4px; }

.conf-fee-upload-form { margin-top: 12px; }
.conf-fee-upload-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: #374151;
  margin-bottom: 8px;
}

.conf-fee-file-input { font-size: 13px; display: block; margin-bottom: 10px; }

.conf-fee-preview { margin: 8px 0 12px; }
.conf-fee-thumb {
  max-width: 200px;
  max-height: 130px;
  border-radius: 8px;
  border: 1.5px solid #e5e7eb;
  object-fit: cover;
}

/* ══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE TWEAKS
══════════════════════════════════════════════════════════════════════════════ */

@media (max-width: 480px) {
  .conf-abstract-card,
  .conf-fee-card { padding: 14px 14px; }
  .conf-form-footer { flex-direction: column; align-items: flex-start; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   REGISTRATION FORM — VISIBILITY FIXES
   Ensure the auth pane scrolls and the Register button is never clipped
══════════════════════════════════════════════════════════════════════════════ */
.conf-auth-pane,
.conf-auth-col {
  /*overflow-y: auto !important;*/
  max-height: none !important;
}
.conf-auth-shell {
  max-height: none !important;
  overflow: visible !important;
}
.conf-auth-panels {
  overflow: visible !important;
}
.conf-register-form p,
.conf-auth-form p {
  margin-bottom: 10px !important;
}
/* Compact the extra fields section */
.conf-auth-form hr { margin: 12px 0 !important; }
.conf-auth-form p:has(select) select,
.conf-auth-form select {
  width: 100%;
  padding: 8px 10px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 13px;
  color: #1f2937;
  background: #fff;
  appearance: auto;
  cursor: pointer;
}

/* ══════════════════════════════════════════════════════════════════════════════
   COLLAPSIBLE ABSTRACT (approved state)
══════════════════════════════════════════════════════════════════════════════ */
.conf-abstract-details {
  border: 1px solid #d1fae5;
  border-radius: 10px;
  margin-top: 10px;
  overflow: hidden;
}
.conf-abstract-summary {
  padding: 11px 16px;
  background: #f0fdf4;
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  color: #065f46;
  list-style: none;
  user-select: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.conf-abstract-summary::-webkit-details-marker { display: none; }
.conf-abstract-summary::before { content: '▶'; font-size: 11px; transition: transform .2s; }
.conf-abstract-details[open] .conf-abstract-summary::before { transform: rotate(90deg); }
.conf-abstract-details > form.conf-abstract-form {
  padding: 14px 16px;
  border-top: 1px solid #d1fae5;
}

/* ── Payment proof box ── */
.conf-payment-box {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
  padding: 12px 14px;
  font-size: 13px;
  color: #1e40af;
  margin-bottom: 10px;
}
.conf-payment-box strong { display: block; margin-bottom: 4px; color: #1e40af; }
.conf-payment-text { color: #374151; margin-top: 4px; line-height: 1.6; }

/* ── Notification icon ── */
.notification_icon_admin { font-size: 14px; }

/* ── JS Accordion (replaces <details>/<summary> for cache-safety) ── */
.conf-accordion-toggle {
  width: 100%;
  text-align: left;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 10px;
  padding: 11px 16px;
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  color: #065f46;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: 10px;
  transition: background .15s;
}
.conf-accordion-toggle:hover { background: #dcfce7; }
.conf-accordion-toggle .conf-acc-caret { font-size: 11px; transition: transform .22s; }
.conf-accordion-toggle.is-open .conf-acc-caret { transform: rotate(90deg); }
.conf-accordion-body {
  display: none;
  padding: 14px 0 0;
}
.conf-accordion-body.is-open { display: block; }

/* ── Payment proof preview in abstract form ── */
.conf-fee-proof-preview img {
  max-width: 180px;
  max-height: 110px;
  border-radius: 6px;
  border: 1.5px solid #e5e7eb;
  object-fit: cover;
  display: block;
  margin-top: 6px;
}
/* ── Passed deadline card ── */
.conf-abstract-card--passed .conf-abstract-card__header { opacity: .7; }

/* ── Realtime indicator ── */
.conf-realtime-dot {
  display: inline-block;
  width: 7px; height: 7px;
  background: #16a34a;
  border-radius: 50%;
  margin-right: 5px;
  animation: conf-pulse 2s ease-in-out infinite;
}
@keyframes conf-pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(.7); }
}

/* ── Presenter-only tab: hidden until user registers as presenter ── */
.conf-presenter-tab-hidden {
  display: none !important;
}

/* ── Participant-only tab: hidden until user registers as participant ── */
.conf-participant-tab-hidden {
  display: none !important;
}

/* ── Register form: page-level scroll only, no inner scrollbar ── */
.conf-register-form {
  max-height: none !important;
  overflow: visible !important;
}

/* ── Submit Abstract CTA in registration cards ── */
.conf-mini__actions .conf-goto-abstract-btn {
  color: #0086A3 !important;
  font-weight: 700 !important;
}
.conf-mini__actions .conf-goto-abstract-btn:hover {
  text-decoration: underline;
}

/* ── Pay Fee CTA in registration cards ── */
.conf-mini__actions .conf-goto-fee-btn {
  color: #0086A3 !important;
  font-weight: 700 !important;
}
.conf-mini__actions .conf-goto-fee-btn:hover {
  text-decoration: underline;
}

/* ── Registration success flash CTA button ── */
.conf-inline-success button.conf-goto-abstract-btn {
  background: #0086A3;
  color: #fff;
  border: none;
  border-radius: 20px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  margin-left: 8px;
  transition: background .15s;
}
.conf-inline-success button.conf-goto-abstract-btn:hover {
  background: #006a82;
}

/* ── Registration success flash CTA button (Pay Fee) ── */
.conf-inline-success button.conf-goto-fee-btn {
  background: #0086A3;
  color: #fff;
  border: none;
  border-radius: 20px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  margin-left: 8px;
  transition: background .15s;
}
.conf-inline-success button.conf-goto-fee-btn:hover {
  background: #006a82;
}
