/* ==========================================================
   Digital Dimensions · Registry Page Styles
   File: assets/css/registry.css
   Applies when body has class: page-registry
   ========================================================== */

.page-registry{
  --dd-accent: var(--accent);
  --dd-text: var(--text);
  --dd-text-soft: rgba(229,231,235,.92);
  --dd-text-muted: rgba(148,163,184,.90);
  --dd-success: var(--good);
  --dd-danger: var(--bad);

  --dd-shadow-soft: 0 14px 34px rgba(0,0,0,.35);
  --dd-shadow-strong: 0 22px 56px rgba(0,0,0,.45);

  --dd-radius-pill: 999px;
  --dd-radius-lg: 18px;
  --dd-radius-md: 14px;
  --dd-radius-sm: 12px;

  --dd-border: rgba(148,163,184,.45);
  --dd-border-soft: rgba(148,163,184,.30);
  --dd-panel: rgba(15,23,42,.92);
  --dd-panel2: rgba(2,6,23,.45);
  --dd-input: #020617;
}

.page-registry *{ box-sizing:border-box; }

.page-registry a{
  color: var(--dd-accent);
  text-decoration: none;
}
.page-registry a:hover{ text-decoration: underline; }

/* Utility */
.page-registry .dd-nowrap{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.page-registry .sr-only{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* ==========================================================
   Hero (override site.css hero subtly for this page)
   ========================================================== */

.page-registry .dd-hero{
  margin-top: 0.9rem;
  padding: 1.8rem 1.6rem 1.6rem;
  border-radius: var(--dd-radius-lg);
  background:
    radial-gradient(circle at 85% 0%, rgba(56,189,248,.16), transparent 55%),
    linear-gradient(135deg, rgba(15,23,42,.96), rgba(15,23,42,.82));
  border: 1px solid var(--dd-border);
  box-shadow: var(--dd-shadow-soft);
  margin-bottom: 1.2rem;
}

.page-registry .dd-hero-kicker{
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dd-text-muted);
  margin-bottom: 0.5rem;
}

.page-registry .dd-hero h2{
  margin: 0 0 0.6rem;
  font-size: clamp(1.7rem, 2.2vw + 1rem, 2.35rem);
}

.page-registry .dd-hero p{
  margin: 0.35rem 0;
  font-size: 0.98rem;
  color: var(--dd-text-soft);
  max-width: 54rem;
}
.page-registry .dd-hero p strong{ color:#f9fafb; }

/* ==========================================================
   View switch
   ========================================================== */

.page-registry .dd-view-switch{
  margin-top: 1.2rem;
  margin-bottom: 1.1rem;
  display: inline-flex;
  border-radius: var(--dd-radius-pill);
  padding: 0.2rem;
  background: rgba(15,23,42,.90);
  border: 1px solid rgba(148,163,184,.50);
  gap: 0.25rem;
}

.page-registry .dd-view-switch .view-btn{
  border: none;
  background: transparent;
  color: var(--dd-text-muted);
  padding: 0.45rem 0.95rem;
  border-radius: var(--dd-radius-pill);
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, transform .08s ease;
}

.page-registry .dd-view-switch .view-btn:hover{
  transform: translateY(-1px);
}

.page-registry .dd-view-switch .view-btn.active{
  background: linear-gradient(135deg, #38bdf8, #0ea5e9);
  color: #020617;
}

/* ==========================================================
   Section container
   ========================================================== */

.page-registry .dd-section{
  margin-top: 0.4rem;
  padding: 1.35rem 1.3rem 1.4rem;
  border-radius: var(--dd-radius-lg);
  background: rgba(15,23,42,.95);
  border: 1px solid rgba(148,163,184,.45);
  box-shadow: 0 18px 42px rgba(8,47,73,.55);
}

.page-registry .view-section{ display:none; }
.page-registry .view-section.active{ display:block; }

.page-registry .dd-section-header h2{
  margin: 0 0 0.45rem;
  font-size: 1.08rem;
}

.page-registry .dd-section-header p{
  margin: 0;
  font-size: 0.94rem;
  color: var(--dd-text-soft);
}

/* ==========================================================
   Alerts
   ========================================================== */

.page-registry .dd-alert{
  margin-top: 0.85rem;
  margin-bottom: 1rem;
  padding: 0.75rem 0.95rem;
  border-radius: 12px;
  font-size: 0.84rem;
  border: 1px solid var(--dd-border);
  background: rgba(2,6,23,.35);
}

.page-registry .dd-alert-success{
  background: rgba(34,197,94,.12);
  border-color: rgba(34,197,94,.60);
  color: var(--dd-success);
}

.page-registry .dd-alert-error{
  background: rgba(248,113,113,.08);
  border-color: rgba(248,113,113,.60);
  color: var(--dd-danger);
}

/* ==========================================================
   DataTables / Registry table
   ========================================================== */

.page-registry .dd-table-wrapper{
  margin-top: 0.95rem;
  overflow-x:auto;
  border-radius: var(--dd-radius-md);
}

/* Keep DataTables background consistent */
.page-registry table.dataTable{
  width: 100% !important;
  background: #020617 !important;
  color: var(--dd-text) !important;
  border-collapse: collapse !important;
}

.page-registry table.dataTable thead{
  background: #020617 !important;
}

.page-registry table.dataTable thead th{
  border-bottom: 1px solid rgba(148,163,184,.40) !important;
  color: var(--dd-text-muted) !important;
  font-weight: 700 !important;
  font-size: 0.78rem !important;
  white-space: nowrap;
}

.page-registry table.dataTable td,
.page-registry table.dataTable th{
  padding: 0.55rem 0.55rem !important;
}

.page-registry table.dataTable tbody tr{
  background: #020617 !important;
}
.page-registry table.dataTable tbody tr:hover{
  background: rgba(56,189,248,.06) !important;
}

.page-registry .dataTables_wrapper .dataTables_length label,
.page-registry .dataTables_wrapper .dataTables_filter label{
  color: var(--dd-text-muted);
  font-size: 0.8rem;
}

.page-registry .dataTables_wrapper .dataTables_filter input{
  background: #020617;
  border: 1px solid rgba(148,163,184,.55);
  border-radius: 999px;
  padding: 0.35rem 0.7rem;
  color: var(--dd-text);
  outline:none;
}
.page-registry .dataTables_wrapper .dataTables_filter input:focus{
  border-color: rgba(56,189,248,.55);
  box-shadow: 0 0 0 2px rgba(56,189,248,.20);
}

.page-registry .dataTables_wrapper .dataTables_info{
  color: var(--dd-text-muted);
  font-size: 0.78rem;
}

.page-registry .dataTables_wrapper .dataTables_paginate a{
  color: var(--dd-text-soft) !important;
  font-size: 0.78rem !important;
}

.page-registry .dataTables_wrapper .dataTables_paginate .current{
  background: linear-gradient(135deg, #38bdf8, #0ea5e9) !important;
  border-radius: 999px !important;
  color: #020617 !important;
  border: none !important;
}

.page-registry .dd-link-btn{
  border-radius: var(--dd-radius-pill);
  border: 1px solid rgba(148,163,184,.85);
  background: rgba(15,23,42,.96);
  color: var(--dd-text-soft);
  padding: 0.24rem 0.75rem;
  font-size: 0.78rem;
  font-weight: 800;
  cursor: pointer;
  white-space: nowrap;
  transition: border-color .15s ease, transform .08s ease, color .15s ease, background .15s ease;
}

.page-registry .dd-link-btn:hover{
  border-color: rgba(56,189,248,.65);
  color: #e0f2fe;
  transform: translateY(-1px);
  background: rgba(56,189,248,.08);
}

/* ==========================================================
   IMPORTANT: Fix "squeezed" register form
   site.css makes .dd-form a 12-col grid globally.
   On this page, only inside #form-view, we want normal flow.
   ========================================================== */

.page-registry #form-view form.dd-form{
  display: block;
  gap: 0;
}
.page-registry #form-view form.dd-form > *{
  max-width: 100%;
}

/* ==========================================================
   Form base (still reuses your existing markup)
   ========================================================== */

.page-registry .dd-form{
  margin-top: 0.85rem;
}

/* Field group spacing */
.page-registry .field-group{
  display:flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 0.95rem;
}

.page-registry .field-group label{
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--dd-text-soft);
}

.page-registry .helper{
  font-size: 0.76rem;
  color: var(--dd-text-muted);
  line-height: 1.45;
}

.page-registry .muted-chip{
  display:inline-flex;
  align-items:center;
  padding: 0.14rem 0.55rem;
  border-radius: var(--dd-radius-pill);
  border: 1px solid rgba(148,163,184,.55);
  font-size: 0.7rem;
  color: var(--dd-text-muted);
  margin-left: 0.35rem;
}

/* Inputs (register tab only feel nicer) */
.page-registry .dd-form input[type="text"],
.page-registry .dd-form input[type="email"],
.page-registry .dd-form input[type="number"],
.page-registry .dd-form select,
.page-registry .dd-form textarea{
  width:100%;
  background: var(--dd-input);
  border-radius: 12px;
  border: 1px solid rgba(148,163,184,.55);
  padding: 0.62rem 0.75rem;
  font-size: 0.92rem;
  color: var(--dd-text);
  outline:none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.page-registry .dd-form input::placeholder,
.page-registry .dd-form textarea::placeholder{
  color: #4b5563;
}

.page-registry .dd-form input:focus,
.page-registry .dd-form textarea:focus,
.page-registry .dd-form select:focus{
  border-color: rgba(56,189,248,.65);
  box-shadow: 0 0 0 2px rgba(56,189,248,.18);
  background: #020617;
}

.page-registry .dd-form textarea{
  min-height: 150px;
  resize: vertical;
}

/* Two-column helper blocks (socials, identity) */
.page-registry .two-col{
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap: 0.65rem;
}
@media (max-width: 680px){
  .page-registry .two-col{
    grid-template-columns: minmax(0,1fr);
  }
}

/* ==========================================================
   Track options (lane cards)
   ========================================================== */

.page-registry .track-options{
  display:flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0.35rem;
}

.page-registry .track-card{
  border-radius: 14px;
  padding: 0.95rem 0.95rem;
  border: 1px solid rgba(148,163,184,.60);
  background:
    radial-gradient(circle at 0 0, rgba(56,189,248,.16), transparent 55%),
    rgba(2,6,23,.35);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.75rem;
  font-size: 0.86rem;
  cursor: pointer;
  transition: transform .08s ease, border-color .15s ease, box-shadow .15s ease;
}

.page-registry .track-card.creator{
  background:
    radial-gradient(circle at 0 0, rgba(168,85,247,.20), transparent 55%),
    rgba(2,6,23,.35);
}

.page-registry .track-card:hover{
  transform: translateY(-1px);
  border-color: rgba(56,189,248,.55);
  box-shadow: var(--dd-shadow-soft);
}

.page-registry .track-card.creator:hover{
  border-color: rgba(168,85,247,.65);
}

.page-registry .track-card input[type="radio"]{
  margin-top: 0.25rem;
  transform: scale(1.05);
}

.page-registry .track-title{
  font-weight: 900;
  font-size: 0.92rem;
  margin-bottom: 0.25rem;
  color: rgba(255,255,255,.95);
}

.page-registry .track-tag{
  display: inline-flex;
  align-items: center;
  padding: 0.10rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.75);
  font-size: 0.75rem;
  margin-left: 0.35rem;
  color: var(--dd-text-soft);
  background: rgba(15,23,42,.55);
}

.page-registry .track-tag.brand{
  border-color: rgba(168,85,247,.90);
}

/* Selected lane glow (modern browsers) */
.page-registry .track-card:has(input[type="radio"]:checked){
  border-color: rgba(56,189,248,.75);
  box-shadow: 0 0 0 2px rgba(56,189,248,.20), var(--dd-shadow-soft);
}
.page-registry .track-card.creator:has(input[type="radio"]:checked){
  border-color: rgba(168,85,247,.80);
  box-shadow: 0 0 0 2px rgba(168,85,247,.18), var(--dd-shadow-soft);
}

/* ==========================================================
   Checkbox rows (make them readable)
   ========================================================== */

.page-registry .checkbox-row{
  display:flex;
  align-items:flex-start;
  gap: 0.65rem;
  font-size: 0.86rem;
  line-height: 1.45;
  background: rgba(2,6,23,.25);
  border: 1px solid rgba(148,163,184,.35);
  border-radius: 14px;
  padding: 0.75rem 0.8rem;
}

.page-registry .checkbox-row input[type="checkbox"]{
  margin-top: 0.22rem;
  transform: scale(1.05);
  flex: 0 0 auto;
}

/* ==========================================================
   Buttons row
   ========================================================== */

.page-registry .btn-row{
  display:flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.0rem;
}

.page-registry .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 0.55rem 1.2rem;
  border-radius: var(--dd-radius-pill);
  border: 1px solid transparent;
  font-size: 0.88rem;
  font-weight: 900;
  cursor:pointer;
  white-space: nowrap;
  transition: background .15s ease, transform .08s ease, box-shadow .15s ease, border-color .15s ease;
}

.page-registry .btn-primary{
  background: linear-gradient(135deg, #38bdf8, #0ea5e9);
  color: #020617;
  box-shadow: 0 12px 28px rgba(8,47,73,.75);
}

.page-registry .btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 40px rgba(8,47,73,.90);
}

.page-registry .btn-ghost{
  background: transparent;
  border-color: rgba(148,163,184,.75);
  color: var(--dd-text-muted);
}

.page-registry .btn-ghost:hover{
  border-color: rgba(56,189,248,.55);
  color: #e0f2fe;
}

/* Footer note on this page */
.page-registry .dd-footer-note{
  margin-top: 1.6rem;
  font-size: 0.84rem;
  text-align: center;
  color: var(--dd-text-muted);
}

/* ==========================================================
   Modal (Profile view)
   ========================================================== */

.page-registry .dd-modal{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 60;
}
.page-registry .dd-modal.open{ display:flex; }

.page-registry .dd-modal-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,.80);
  backdrop-filter: blur(4px);
}

.page-registry .dd-modal-dialog{
  position: relative;
  max-width: 680px;
  width: 100%;
  margin: 1.25rem;
  z-index: 61;
}

.page-registry .dd-modal-content{
  border-radius: 18px;
  background: rgba(15,23,42,.98);
  border: 1px solid rgba(148,163,184,.60);
  box-shadow: 0 26px 60px rgba(15,23,42,.92);
  padding: 1.3rem 1.3rem 1.15rem;
  max-height:540px;
  overflow-y:scroll;
}

.page-registry .dd-modal-header{
  display:flex;
  justify-content: space-between;
  gap: 0.9rem;
  align-items: flex-start;
  margin-bottom: 0.75rem;
}

.page-registry .dd-modal-kicker{
  font-size: 0.76rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dd-text-muted);
  margin-bottom: 0.25rem;
}

.page-registry .dd-modal-title{
  margin: 0;
  font-size: 1.08rem;
}

.page-registry .dd-modal-subtitle{
  font-size: 0.82rem;
  color: var(--dd-text-muted);
}

.page-registry .dd-modal-close{
  position: absolute;
  top: 0.65rem;
  right: 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.50);
  width: 30px;
  height: 30px;
  background: rgba(15,23,42,.90);
  color: var(--dd-text-soft);
  font-size: 1.05rem;
  cursor: pointer;
  transition: border-color .15s ease, transform .08s ease;
}

.page-registry .dd-modal-close:hover{
  border-color: rgba(56,189,248,.65);
  transform: translateY(-1px);
}

.page-registry .dd-modal-section{
  margin-top: 0.65rem;
  padding-top: 0.65rem;
  border-top: 1px dashed rgba(148,163,184,.35);
}

.page-registry .dd-modal-section h4{
  margin: 0 0 0.35rem;
  font-size: 0.92rem;
}

.page-registry .dd-modal-section p{
  margin: 0 0 0.4rem;
  font-size: 0.86rem;
  color: var(--dd-text-soft);
  line-height: 1.55;
}

.page-registry .dd-modal-section ul{
  margin: 0.15rem 0 0.4rem 1.1rem;
  padding-left: 0.2rem;
  font-size: 0.84rem;
  color: var(--dd-text-soft);
}

.page-registry .dd-modal-note{
  font-size: 0.80rem;
  color: var(--dd-text-muted);
  line-height: 1.45;
}

.page-registry .dd-modal-footer{
  margin-top: 0.65rem;
  padding-top: 0.55rem;
  border-top: 1px dashed rgba(148,163,184,.35);
  font-size: 0.82rem;
  color: var(--dd-text-muted);
}

.page-registry .dd-cta-btn{
  border-radius: var(--dd-radius-pill);
  border: 1px solid rgba(148,163,184,.75);
  padding: 0.38rem 0.95rem;
  font-size: 0.82rem;
  font-weight: 900;
  background: rgba(15,23,42,.96);
  color: var(--dd-text-soft);
  display:inline-flex;
  align-items:center;
  gap: 0.45rem;
  text-decoration:none;
  transition: border-color .15s ease, transform .08s ease, background .15s ease;
  margin-right:20px;
}

.page-registry .dd-cta-btn:hover{
  text-decoration:none;
  border-color: rgba(56,189,248,.65);
  transform: translateY(-1px);
  background: rgba(56,189,248,.08);
}

.page-registry .dd-cta-btn span.icon{
  font-size: 0.95rem;
  line-height: 1;
}

/* Mobile tweaks */
@media (max-width: 640px){
  .page-registry .dd-hero{
    padding: 1.45rem 1.1rem 1.25rem;
  }
  .page-registry .checkbox-row{
    padding: 0.7rem 0.75rem;
  }
}

/* ==========================================================
   Force header/menu link color to stay consistent on registry pages
   (leave these at the bottom)
   ========================================================== */

.dd-header a,
.dd-header a:visited,
.dd-nav a,
.dd-nav a:visited,
.dd-mega a,
.dd-mega a:visited{
  color: var(--text) !important;
}

.dd-header a:hover,
.dd-nav a:hover,
.dd-mega a:hover{
  color: #ffffff !important;
}


/* --- Month input: make it match reg-form styling --- */
.reg-form input[type="month"]{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: textfield;

  width: 100%;
  min-height: 44px;
  padding: 12px 14px;

  border-radius: 14px;
  border: 1px solid var(--border, rgba(148,163,184,.20));
  background: rgba(2,6,23,.52);
  color: var(--text, #e5e7eb);

  outline: none;
  box-shadow: 0 0 0 1px rgba(255,255,255,.03) inset;
}

/* Focus state */
.reg-form input[type="month"]:focus{
  border-color: rgba(255,255,255,.35);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.18) inset,
    0 0 0 3px rgba(255,255,255,.10);
}

/* Make the calendar icon less ugly / more visible */
.reg-form input[type="month"]::-webkit-calendar-picker-indicator{
  opacity: .85;
  filter: invert(1);
  cursor: pointer;
}

/* Some browsers render internal parts with their own colors */
.reg-form input[type="month"]::-webkit-datetime-edit{
  color: var(--text, #e5e7eb);
}
.reg-form input[type="month"]::-webkit-datetime-edit-fields-wrapper{
  padding: 0;
}
.reg-form input[type="month"]::-webkit-datetime-edit-text{
  opacity: .7;
}

/* Placeholder-ish look when empty (Chrome sometimes shows blank) */
.reg-form input[type="month"]:not([value]),
.reg-form input[type="month"][value=""]{
  color: rgba(148,163,184,.85);
}


/* ==========================================================
   Custom Scrollbars (scoped to .scroll-y)
   Usage: <div class="scroll-y">...</div>
   ========================================================== */

.scroll-y{
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;

  /* Firefox */
  scrollbar-width: thin;
  scrollbar-color: rgba(148,163,184,.55) rgba(2,6,23,.28);

  /* Optional: prevents layout shift when scrollbar appears */
  scrollbar-gutter: stable;
}

/* WebKit (Chrome/Edge/Safari) */
.scroll-y::-webkit-scrollbar{
  width: 10px;
}

.scroll-y::-webkit-scrollbar-track{
  background: rgba(2,6,23,.28);
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.12);
}

.scroll-y::-webkit-scrollbar-thumb{
  background: linear-gradient(
    to bottom,
    rgba(148,163,184,.70),
    rgba(148,163,184,.45)
  );
  border-radius: 999px;
  border: 2px solid rgba(2,6,23,.40); /* creates padding effect */
}

.scroll-y::-webkit-scrollbar-thumb:hover{
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,.70),
    rgba(148,163,184,.55)
  );
}

/* Optional: a tiny “corner” polish if both axes scroll */
.scroll-y::-webkit-scrollbar-corner{
  background: rgba(2,6,23,.28);
}
