:root {
  --bg: #161820;
  --bg-deep: #0e1016;
  --sidebar: #1d202a;
  --card: #242733;
  --card-2: #1b1d26;
  --input: #12141b;
  --line: rgba(255,255,255,0.075);
  --line-strong: rgba(255,255,255,0.13);
  --text: #f8f7fb;
  --muted: #9ca3b7;
  --muted-2: #747b90;
  --orange: #ff7a18;
  --orange-2: #ff9f43;
  --blue: #4d9cff;
  --green: #45d483;
  --danger: #ff5c77;
  --purple: #a66cff;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, Segoe UI, Arial, sans-serif;
  background: radial-gradient(circle at top left, rgba(255,122,24,0.12), transparent 32rem), var(--bg-deep);
  color: var(--text);
}
a { color: inherit; text-decoration: none; }
code { background: rgba(255,255,255,0.08); padding: .15rem .35rem; border-radius: .35rem; color: #fff; }
.bg-orb { position: fixed; border-radius: 999px; filter: blur(90px); opacity: .24; pointer-events: none; }
.orb-one { width: 24rem; height: 24rem; left: -8rem; top: 3rem; background: var(--orange); }
.orb-two { width: 26rem; height: 26rem; right: -10rem; bottom: -8rem; background: #8b5cf6; }

.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.5rem; border-bottom: 1px solid var(--line);
  background: rgba(11,12,16,.82); backdrop-filter: blur(16px); position: sticky; top: 0; z-index: 10;
}
.brand, .sidebar-logo { display: flex; align-items: center; gap: .7rem; font-weight: 900; letter-spacing: .01em; }
.brand-mark { color: var(--orange); font-size: 1.1rem; display: inline-grid; place-items: center; }
.brand-mark.large { width: 3rem; height: 3rem; border-radius: 1rem; background: linear-gradient(135deg, rgba(255,122,24,.24), rgba(255,255,255,.06)); font-size: 2rem; }
.navlinks, .top-actions { display: flex; gap: .8rem; color: var(--muted); }
.navlinks a:hover, .top-actions a:hover { color: var(--text); }
.container { width: min(1180px, calc(100vw - 2rem)); margin: 1.5rem auto 3rem; }
.card {
  background: linear-gradient(180deg, rgba(36,39,51,.96), rgba(27,29,38,.96));
  border: 1px solid var(--line); border-radius: 1.15rem;
  box-shadow: 0 20px 60px rgba(0,0,0,.22); padding: 1.5rem;
}
.eyebrow { color: var(--orange); text-transform: uppercase; font-size: .75rem; font-weight: 900; letter-spacing: .16em; margin: 0 0 .4rem; }
h1, h2, h3 { margin: 0; letter-spacing: -.025em; }
h1 { font-size: clamp(2rem, 4vw, 3.1rem); }
h2 { font-size: clamp(1.25rem, 2vw, 1.65rem); }
.muted { color: var(--muted); }
.big-muted { font-size: 1.02rem; line-height: 1.55; }
.small { font-size: .85rem; }
.mini-label { margin: 0 0 .2rem; color: var(--orange); font-size: .72rem; font-weight: 900; text-transform: uppercase; letter-spacing: .12em; }

.dash-hero { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; margin-bottom: 1rem; }
.status-stack { text-align: right; }
.status-pill, .secondary-button, .arrow-pill {
  border: 1px solid var(--line-strong); background: rgba(255,255,255,0.06); color: var(--muted);
  padding: .72rem 1rem; border-radius: 999px; white-space: nowrap; display: inline-flex; align-items: center; gap: .5rem;
}
.online-dot::before { content: ''; width: .55rem; height: .55rem; background: var(--green); border-radius: 999px; box-shadow: 0 0 0 4px rgba(69,212,131,.12); }
.secondary-button:hover { border-color: rgba(255,122,24,.5); color: var(--text); }
.server-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem; }
.server-card { display: flex; gap: 1rem; align-items: center; transition: .16s ease; }
.server-card:hover { transform: translateY(-2px); border-color: rgba(255,122,24,.55); }
.server-icon, .server-mini-icon {
  border-radius: 1rem; display: grid; place-items: center; background: var(--card-2); color: var(--orange); overflow: hidden; flex: none;
}
.server-icon { width: 4.4rem; height: 4.4rem; font-size: 2.1rem; }
.server-mini-icon { width: 2.6rem; height: 2.6rem; font-size: 1.4rem; }
.server-icon img, .server-mini-icon img { width: 100%; height: 100%; object-fit: cover; }
.server-card-copy { flex: 1; min-width: 0; }
.empty-state { text-align: center; }

.login-card { width: min(430px, 100%); margin: 5rem auto; text-align: center; }
.logo-mark { width: 5rem; height: 5rem; margin: 0 auto 1rem; border-radius: 1.4rem; display: grid; place-items: center; background: linear-gradient(135deg, rgba(255,122,24,.25), rgba(255,255,255,.06)); color: var(--orange); font-size: 3rem; }

.app-shell-page { background: radial-gradient(circle at 70% 0%, rgba(255,122,24,.08), transparent 28rem), var(--bg); }
.app-shell { display: grid; grid-template-columns: 320px minmax(0, 1fr); min-height: 100vh; }
.sidebar {
  position: sticky; top: 0; height: 100vh; overflow-y: auto; padding: 1.6rem 1rem;
  background: rgba(29,32,42,.96); border-right: 1px solid var(--line); z-index: 20;
}
.sidebar-logo { font-size: 1.55rem; margin: 0 .35rem 1.45rem; }
.server-switcher {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: .75rem;
  padding: .9rem; border-radius: .9rem; background: rgba(0,0,0,.18); border: 1px solid var(--line); margin-bottom: 1.5rem;
}
.server-switcher span:not(.chevron) { display: block; color: var(--muted); font-size: .82rem; margin-top: .15rem; }
.chevron { color: var(--muted); font-size: 1.2rem; }
.side-nav { display: flex; flex-direction: column; gap: .25rem; }
.side-section { color: #fff; text-transform: uppercase; font-size: .73rem; font-weight: 900; letter-spacing: .12em; margin: 1.35rem .8rem .45rem; }
.side-nav a {
  display: flex; align-items: center; gap: .8rem; min-height: 2.7rem; padding: .7rem .85rem; color: var(--muted);
  border-radius: .75rem; position: relative; font-weight: 700;
}
.side-nav a:hover, .side-nav a.active { color: var(--text); background: rgba(255,255,255,.06); }
.side-nav a.active::before { content: ''; width: .45rem; height: .45rem; border-radius: 999px; background: var(--blue); position: absolute; left: -.05rem; }
.side-nav a.disabled { opacity: .72; cursor: default; }
.side-nav a.disabled em { margin-left: auto; font-size: .65rem; color: var(--orange-2); font-style: normal; text-transform: uppercase; }
.main-panel { padding: 1.6rem 2rem 4rem; min-width: 0; }
.app-topbar { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin-bottom: 1.25rem; }
.alert { border-radius: .9rem; padding: .9rem 1rem; margin: 1rem 0; border: 1px solid var(--line); }
.alert.success { background: rgba(69,212,131,.12); color: #c9f7dd; border-color: rgba(69,212,131,.22); }
.module-hero { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; margin-bottom: 1rem; }
.module-stats { display: grid; grid-template-columns: repeat(3, minmax(90px, 1fr)); gap: .65rem; }
.module-stats div { padding: .85rem 1rem; border-radius: .9rem; border: 1px solid var(--line); background: rgba(0,0,0,.14); text-align: center; }
.module-stats strong { display: block; font-size: 1.45rem; }
.module-stats span { display: block; color: var(--muted); font-size: .8rem; margin-top: .15rem; }
.module-grid { display: grid; grid-template-columns: repeat(2, minmax(320px, 1fr)); gap: 1rem; align-items: start; }
.module-card { margin-bottom: 1rem; }
.module-card-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-bottom: 1rem; border-bottom: 1px solid var(--line); margin-bottom: 1rem; }
.module-card-header.compact { align-items: flex-start; }
.module-card-header p { margin: .4rem 0 0; line-height: 1.45; }
.module-state {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem; padding: .45rem .7rem; border-radius: 999px;
  color: var(--muted); background: rgba(255,255,255,.06); border: 1px solid var(--line); font-size: .82rem; font-weight: 900;
}
.module-state::before { content: ''; width: .45rem; height: .45rem; border-radius: 999px; background: var(--muted-2); }
.module-state.is-on { color: #dafbe9; background: rgba(69,212,131,.12); border-color: rgba(69,212,131,.2); }
.module-state.is-on::before { background: var(--green); }
.featured-module { border-color: rgba(255,122,24,.25); }

.rbg-form { display: flex; flex-direction: column; gap: .85rem; }
.split-form { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 1.1rem; align-items: start; }
.form-main { display: flex; flex-direction: column; gap: .85rem; }
.form-grid.two { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
label { color: #e4e6ef; font-weight: 800; font-size: .9rem; }
input, select, textarea {
  width: 100%; padding: .88rem 1rem; border-radius: .75rem; border: 1px solid var(--line);
  background: var(--input); color: var(--text); outline: none; min-height: 2.85rem;
}
textarea { resize: vertical; line-height: 1.4; }
input:focus, select:focus, textarea:focus { border-color: rgba(255,122,24,.8); box-shadow: 0 0 0 3px rgba(255,122,24,.09); }
button {
  border: 0; border-radius: .8rem; padding: .9rem 1.1rem; font-weight: 900; cursor: pointer;
  background: linear-gradient(135deg, var(--orange), var(--orange-2)); color: #1a1006; min-height: 2.9rem;
}
button:hover { filter: brightness(1.06); }
button.danger { background: rgba(255,92,119,.13); color: #ffb5c1; border: 1px solid rgba(255,92,119,.35); }
.toggle-row {
  display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 1rem; border-radius: .9rem;
  border: 1px solid var(--line); background: rgba(0,0,0,.14);
}
.toggle-row small { display: block; color: var(--muted); font-weight: 600; margin-top: .25rem; }
.toggle-row input[type="checkbox"] { width: 44px; min-height: 24px; height: 24px; appearance: none; border-radius: 999px; padding: 0; background: #3b4152; border: 0; position: relative; cursor: pointer; }
.toggle-row input[type="checkbox"]::after { content: ''; position: absolute; width: 18px; height: 18px; top: 3px; left: 3px; border-radius: 999px; background: white; transition: .16s ease; }
.toggle-row input[type="checkbox"]:checked { background: var(--blue); }
.toggle-row input[type="checkbox"]:checked::after { transform: translateX(20px); }
.small-toggle { padding: .8rem .9rem; }
.editor-tabs { display: inline-flex; gap: .25rem; padding: .25rem; border-radius: .8rem; background: rgba(0,0,0,.18); border: 1px solid var(--line); width: fit-content; }
.tab { padding: .65rem .9rem; border-radius: .6rem; font-weight: 800; font-size: .85rem; }
.tab.active { background: rgba(255,255,255,.08); color: var(--text); }
.live-preview { border: 1px solid var(--line); border-radius: 1rem; background: rgba(0,0,0,.14); padding: 1rem; position: sticky; top: 1rem; }
.preview-title { font-weight: 900; margin-bottom: .8rem; color: var(--text); }
.discord-preview { display: grid; grid-template-columns: auto 1fr; gap: .75rem; padding: .9rem; border-radius: .85rem; background: #313442; color: #f4f5f7; }
.preview-avatar { width: 42px; height: 42px; border-radius: 999px; display: grid; place-items: center; background: linear-gradient(135deg, rgba(255,122,24,.4), rgba(255,255,255,.12)); color: var(--orange); }
.discord-preview p { margin: .45rem 0 0; color: #e5e7ef; word-break: break-word; }
.command-module { margin-top: 0; }
.command-form { display: grid; grid-template-columns: minmax(180px, 260px) 1fr auto; align-items: end; }
.command-list { margin-top: 1rem; display: grid; gap: .75rem; }
.command-row { display: flex; justify-content: space-between; gap: 1rem; align-items: center; padding: .9rem; border-radius: .9rem; background: rgba(255,255,255,.04); border: 1px solid var(--line); }
.command-row p { color: var(--muted); margin: .35rem 0 0; white-space: pre-wrap; }

@media (max-width: 1180px) {
  .app-shell { grid-template-columns: 280px minmax(0, 1fr); }
  .split-form { grid-template-columns: 1fr; }
  .live-preview { position: static; }
  .module-grid { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
  .app-shell { display: block; }
  .sidebar { position: relative; height: auto; }
  .main-panel { padding: 1rem; }
  .app-topbar, .dash-hero, .module-hero, .module-card-header { flex-direction: column; align-items: flex-start; }
  .form-grid.two, .command-form, .module-stats { grid-template-columns: 1fr; }
  .status-stack { text-align: left; }
}

/* Welcome & Goodbye embed builder */
.welcome-builder { border-color: rgba(255,122,24,.32); }
.welcome-goodbye-form { grid-template-columns: minmax(0, 1fr) 380px; }
.stacked-builder { gap: 1rem; }
.builder-panel {
  border: 1px solid var(--line);
  border-radius: 1rem;
  padding: 1rem;
  background: rgba(0,0,0,.16);
  display: flex;
  flex-direction: column;
  gap: .85rem;
}
.builder-heading {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  padding-bottom: .85rem;
  border-bottom: 1px solid var(--line);
}
.builder-heading h3 { font-size: 1.05rem; margin: .2rem 0; }
.builder-heading p { margin: 0; }
.switch-only { flex: none; }
.switch-only input { display: none; }
.switch-only span {
  width: 56px;
  height: 30px;
  border-radius: 999px;
  background: #3b4152;
  display: block;
  position: relative;
  cursor: pointer;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
}
.switch-only span::after {
  content: '';
  position: absolute;
  width: 22px;
  height: 22px;
  top: 4px;
  left: 4px;
  border-radius: 999px;
  background: #fff;
  transition: .16s ease;
}
.switch-only input:checked + span { background: var(--blue); }
.switch-only input:checked + span::after { transform: translateX(26px); }
.embed-builder-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 135px;
  gap: .8rem;
  align-items: end;
}
input[type="color"] {
  padding: .25rem;
  height: 48px;
  min-height: 48px;
  cursor: pointer;
}
.wide-save { width: 100%; font-size: .98rem; }
.embed-preview-panel { top: 1.5rem; }
.embed-preview-message { background: #2b2f3d; }
.preview-content { min-width: 0; }
.preview-plain { margin-bottom: .7rem !important; }
.fake-embed {
  border-left: 5px solid var(--orange);
  background: rgba(0,0,0,.22);
  border-radius: .45rem;
  padding: .85rem;
  margin-top: .55rem;
  max-width: 100%;
}
.fake-embed h4 { margin: 0 0 .45rem; color: #fff; }
.fake-embed p { white-space: pre-wrap; color: #d9ddeb; margin: .25rem 0 .7rem; }
.fake-embed small { color: var(--muted); }
.fake-thumb, .fake-image {
  border: 1px dashed rgba(255,255,255,.18);
  border-radius: .65rem;
  padding: .65rem;
  margin: .55rem 0;
  color: var(--muted);
  background: rgba(255,255,255,.04);
  font-size: .82rem;
}
.fake-image { min-height: 90px; display: grid; place-items: center; }
.hint-box {
  margin-top: 1rem;
  display: grid;
  gap: .35rem;
  padding: .9rem;
  border-radius: .9rem;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-size: .85rem;
}
.hint-box strong { color: var(--text); }
@media (max-width: 1180px) {
  .welcome-goodbye-form { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .embed-builder-grid { grid-template-columns: 1fr; }
  .builder-heading { flex-direction: column; }
}

/* Separate module pages */
.overview-grid .overview-card { position: relative; min-height: 190px; display: flex; flex-direction: column; gap: .65rem; }
.overview-card:hover { transform: translateY(-2px); border-color: rgba(255,122,24,.55); }
.card-icon { width: 3rem; height: 3rem; display: grid; place-items: center; border-radius: 1rem; background: rgba(255,255,255,.06); font-size: 1.5rem; }
.overview-card .module-state { margin-top: auto; width: fit-content; }
.narrow-form { max-width: 860px; }
.coming-soon-card { min-height: 300px; display: flex; flex-direction: column; gap: 1rem; justify-content: center; }
.hint-box { display: grid; gap: .45rem; margin-top: .85rem; padding: .9rem; border: 1px solid var(--line); border-radius: .9rem; background: rgba(0,0,0,.16); color: var(--muted); }
.hint-box strong { color: var(--text); }
.hint-box span { display: block; }
.side-nav a em { margin-left: auto; font-size: .65rem; color: var(--orange-2); font-style: normal; text-transform: uppercase; }
@media (max-width: 1180px) { .welcome-goodbye-form { grid-template-columns: 1fr; } }


/* Reaction role builder */
.reaction-role-builder .fake-button-row{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.fake-discord-button{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.14);background:#2f3136;border-radius:8px;padding:9px 12px;color:#f5f5f5;font-weight:800;font-size:13px}
.form-grid.three{display:grid;grid-template-columns:1.2fr 1fr .55fr;gap:14px}
.reaction-panel-list{margin-top:18px}
.reaction-panel-row{display:grid;grid-template-columns:minmax(280px,1.1fr) minmax(360px,1.2fr) 190px;gap:14px;align-items:start;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.035);border-radius:18px;padding:16px;margin-top:14px}
.reaction-panel-info strong{display:block;font-size:17px;margin-bottom:6px}.reaction-panel-info p{margin:0 0 10px}.rr-option-list{display:flex;gap:8px;flex-wrap:wrap}.rr-option-list span{border:1px solid rgba(255,122,24,.25);background:rgba(255,122,24,.08);border-radius:999px;padding:7px 10px;font-size:12px;font-weight:800;color:#ffd8bd}.mini-inline-form{display:grid;grid-template-columns:1fr 1fr .6fr auto;gap:8px}.mini-inline-form select,.mini-inline-form input{min-width:0}.delete-panel-form{display:flex;flex-direction:column;gap:10px;align-items:stretch}.tiny-check{display:flex;gap:8px;align-items:center;color:#aeb2bd;font-size:12px;line-height:1.3}.tiny-check input{width:auto}.danger{background:linear-gradient(135deg,#b42323,#7b1111)!important;box-shadow:none!important}
@media (max-width:1100px){.reaction-panel-row{grid-template-columns:1fr}.mini-inline-form{grid-template-columns:1fr 1fr}.form-grid.three{grid-template-columns:1fr}}

/* Bigger Discord preview + embed image uploads */
.split-form { grid-template-columns: minmax(0, 1fr) minmax(430px, 520px); }
.welcome-goodbye-form { grid-template-columns: minmax(0, 1fr) minmax(460px, 560px); }
.reaction-form { grid-template-columns: minmax(0, 1fr) minmax(480px, 600px); }
.embed-preview-panel { min-width: 0; }
.embed-preview-message { padding: 1.15rem; gap: 1rem; }
.large-discord-preview .fake-embed, .embed-preview-panel .fake-embed { max-width: 100%; }
.media-grid input[type="file"] {
  padding: .65rem .75rem;
  border-style: dashed;
  background: rgba(255,255,255,.035);
}
.file-label {
  display: block;
  margin-top: .6rem;
  color: var(--muted);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.fake-thumb { width: fit-content; padding: .35rem; }
.fake-thumb img { width: 96px; height: 96px; object-fit: cover; border-radius: .6rem; display: block; }
.fake-image { min-height: 210px; padding: .45rem; overflow: hidden; }
.fake-image img { width: 100%; max-height: 340px; object-fit: cover; border-radius: .6rem; display: block; }
.placeholder-image { color: var(--muted); text-align: center; border-style: dashed; display: grid; place-items: center; }
@media (max-width: 1180px) {
  .split-form, .welcome-goodbye-form, .reaction-form { grid-template-columns: 1fr; }
}

/* Extra large preview panels - v2 */
.preview-title { font-size: 1.05rem; }
.discord-preview.embed-preview-message {
  padding: 1.45rem;
  gap: 1.15rem;
  border-radius: 1.1rem;
  min-height: 260px;
}
.embed-preview-panel {
  width: 100%;
}
.preview-avatar {
  width: 54px;
  height: 54px;
  font-size: 1.2rem;
}
.preview-content strong {
  font-size: 1.02rem;
}
.preview-plain,
.discord-preview p {
  font-size: .98rem;
  line-height: 1.45;
}
.fake-embed {
  padding: 1.15rem;
  border-left-width: 6px;
  border-radius: .65rem;
  margin-top: .75rem;
}
.fake-embed h4 {
  font-size: 1.15rem;
  margin-bottom: .65rem;
}
.fake-embed p {
  font-size: .98rem;
  line-height: 1.5;
}
.fake-embed small {
  font-size: .86rem;
}
.fake-thumb img {
  width: 132px;
  height: 132px;
}
.fake-image {
  min-height: 330px;
}
.fake-image img {
  max-height: 520px;
}
.fake-discord-button {
  font-size: .95rem;
  padding: 12px 16px;
}

/* Make module forms dedicate much more space to preview on wide screens */
@media (min-width: 1500px) {
  .split-form { grid-template-columns: minmax(620px, 1fr) minmax(700px, 820px); }
  .welcome-goodbye-form { grid-template-columns: minmax(620px, 1fr) minmax(720px, 860px); }
  .reaction-form { grid-template-columns: minmax(620px, 1fr) minmax(740px, 900px); }
  .main-panel { padding-right: 2.2rem; }
}

@media (min-width: 1900px) {
  .split-form { grid-template-columns: minmax(680px, 1fr) minmax(820px, 980px); }
  .welcome-goodbye-form { grid-template-columns: minmax(680px, 1fr) minmax(840px, 1020px); }
  .reaction-form { grid-template-columns: minmax(680px, 1fr) minmax(860px, 1040px); }
}

/* Giveaway module */
.giveaway-builder { border-color: rgba(255,122,24,.32); }
.giveaway-form { grid-template-columns: minmax(0, 1fr) minmax(520px, 760px); }
.fake-discord-button.primary { background: #5865f2; color: #fff; border-color: rgba(255,255,255,.08); }
.giveaway-list { border-color: rgba(255,122,24,.18); }
.giveaway-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(255,255,255,.04);
  margin-bottom: .8rem;
}
.giveaway-row.is-active { border-color: rgba(69,212,131,.22); background: rgba(69,212,131,.055); }
.giveaway-row.is-ended { opacity: .86; }
.giveaway-info p { margin: .3rem 0 0; }
.giveaway-actions { display: flex; gap: .7rem; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
.giveaway-actions form { display: flex; gap: .5rem; align-items: center; }
.giveaway-actions button { min-height: 2.5rem; padding: .72rem .95rem; }
@media (max-width: 1180px) {
  .giveaway-form { grid-template-columns: 1fr; }
  .giveaway-row { grid-template-columns: 1fr; }
  .giveaway-actions { justify-content: flex-start; }
}
@media (min-width: 1500px) {
  .giveaway-form { grid-template-columns: minmax(620px, 1fr) minmax(740px, 900px); }
}
@media (min-width: 1900px) {
  .giveaway-form { grid-template-columns: minmax(680px, 1fr) minmax(860px, 1040px); }
}


/* Giveaway entrants dashboard viewer */
.entrant-details {
  margin-top: 14px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(0,0,0,.16);
  overflow: hidden;
}
.entrant-details summary {
  cursor: pointer;
  padding: 12px 14px;
  font-weight: 800;
  color: #fff;
  list-style: none;
  background: rgba(255,255,255,.035);
}
.entrant-details summary::-webkit-details-marker { display: none; }
.entrant-details summary::after {
  content: "▾";
  float: right;
  opacity: .75;
}
.entrant-details[open] summary::after { content: "▴"; }
.entrant-grid {
  padding: 14px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 10px;
  max-height: 360px;
  overflow: auto;
}
.entrant-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 12px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.07);
}
.entrant-chip img,
.entrant-avatar-fallback {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  background: rgba(255,122,24,.2);
}
.entrant-chip strong { display: block; font-size: .95rem; }
.entrant-chip small { display: block; color: var(--muted); font-size: .75rem; word-break: break-all; }
.entrant-copy-label { display: block; padding: 0 14px 6px; }
.entrant-copy-box {
  margin: 0 14px 14px;
  width: calc(100% - 28px);
  min-height: 76px;
  resize: vertical;
  color: #d9e2ff;
  background: rgba(0,0,0,.3);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  padding: 10px;
}
.no-entrants { padding: 14px; margin: 0; }


/* Ticket dashboard module */
.ticket-panel-row,
.ticket-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  margin-top: 12px;
}
.ticket-row.is-active { border-color: rgba(255,122,24,.35); background: rgba(255,122,24,.06); }
.ticket-row.is-ended { opacity: .72; }
.ticket-panel-info strong,
.ticket-info strong { display: block; color: #fff; font-size: 1.05rem; margin-bottom: 4px; }
.ticket-panel-info p,
.ticket-info p { margin: 3px 0; }
.ticket-form .builder-panel textarea[name="welcome_message"] { min-height: 120px; }
@media (max-width: 980px) {
  .ticket-panel-row,
  .ticket-row { grid-template-columns: 1fr; }
}

.discord-login-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 13px 16px;
  margin: 16px 0 12px;
  border-radius: 12px;
  background: #5865f2;
  color: white;
  text-decoration: none;
  font-weight: 800;
  box-shadow: 0 10px 30px rgba(88, 101, 242, 0.28);
}
.discord-login-button:hover { filter: brightness(1.08); }
.login-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 12px 0;
  color: var(--muted, #9ca3af);
  font-size: 0.85rem;
}
.login-divider:before,
.login-divider:after {
  content: "";
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,0.12);
}
.auth-pill {
  display: inline-flex;
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  color: var(--muted, #9ca3af);
  background: rgba(255,255,255,0.04);
  margin-bottom: 10px;
}
.alert.warning {
  border-color: rgba(255, 183, 77, 0.35);
  background: rgba(255, 183, 77, 0.10);
  color: #ffd08a;
}


.role-checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
  margin: 8px 0 6px;
}

.role-check {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 12px;
  background: rgba(255,255,255,0.05);
  color: #fff;
  font-weight: 700;
}

.role-check input {
  width: auto;
}

.small-note {
  font-size: 0.86rem;
}

.role-multiselect {
  width: 100%;
  min-height: 190px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: #fff;
  font-weight: 700;
  outline: none;
}

.role-multiselect option {
  padding: 10px 12px;
  margin: 3px 0;
  border-radius: 10px;
  background: #171922;
  color: #fff;
}

.role-multiselect option:checked {
  background: linear-gradient(135deg, #ff8a1f, #ff5a00);
  color: #111;
  font-weight: 900;
}
