/* Shared advertiser form, bid queue, and portal styles */
.adv-card { background: #fff; border: 1px solid var(--line, #e5eaf0); border-radius: 18px; padding: 26px; box-shadow: 0 14px 40px rgba(11,20,36,.06); }
.adv-form { display: grid; gap: 14px; }
.adv-form label.f { display: block; font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: #55627a; margin-bottom: 5px; }
.adv-form label.f small { text-transform: none; letter-spacing: 0; font-weight: 500; }
.adv-form input[type=text], .adv-form input[type=email], .adv-form input[type=url], .adv-form input[type=number] {
  width: 100%; border: 1px solid #d7dee6; border-radius: 9px; padding: 10px 12px; font: inherit; font-size: 14px; background: #fff;
}
.adv-form input:focus { outline: 2px solid #10b98155; border-color: #10b981; }
.adv-two { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.adv-check { display: flex; gap: 8px; align-items: center; font-size: 13.5px; }
.adv-icon-drop { border: 1.5px dashed #c8d2dc; border-radius: 10px; padding: 14px; text-align: center; font-size: 13px; color: #55627a; cursor: pointer; }
.adv-icon-drop.has { border-style: solid; display: flex; align-items: center; justify-content: center; gap: 10px; color: #0b1424; }
.adv-icon-drop img { width: 34px; height: 34px; border-radius: 8px; object-fit: cover; }
.adv-placements { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.adv-placement { border: 1.5px solid #d7dee6; border-radius: 12px; padding: 12px 14px; cursor: pointer; font-size: 12.5px; color: #55627a; }
.adv-placement b { display: block; font-size: 13.5px; color: #0b1424; margin-bottom: 2px; }
.adv-placement.sel { border-color: #10b981; background: #f2fbf7; }
.adv-slider-wrap { border: 1px solid #e5eaf0; border-radius: 12px; padding: 14px 16px; }
.adv-slider-wrap input[type=range] { width: 100%; accent-color: #10b981; }
.adv-slider-labels { display: flex; justify-content: space-between; font-size: 11.5px; color: #55627a; }
.adv-total { background: #f2fbf7; border: 1px solid #c4ecd9; border-radius: 12px; padding: 14px 16px; }
.adv-total .big { font-size: 26px; font-weight: 800; }
.adv-total .grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 10px; }
.adv-total .grid3 div { background: #fff; border: 1px solid #e0efe7; border-radius: 8px; padding: 8px 10px; font-size: 12px; color: #55627a; }
.adv-total .grid3 b { display: block; font-size: 14px; color: #0b1424; }
.adv-preview { background: #0f172a; border-radius: 12px; padding: 14px 16px; }
.adv-preview .tag { font-size: 9px; letter-spacing: .12em; color: #64748b; text-transform: uppercase; margin-bottom: 8px; }
.adv-preview .pcard { display: flex; align-items: center; gap: 10px; color: #e2e8f0; font-size: 14px; }
.adv-preview .pcard img, .adv-preview .pcard .ph { width: 30px; height: 30px; border-radius: 8px; background: linear-gradient(135deg,#4ade80,#2dd4bf); flex: none; }
.adv-preview .pcard b { color: #fff; }
.adv-preview .pcard .co { color: #94a3b8; font-size: 12px; }
.adv-submit { background: var(--mint, #10b981); color: #fff; border: 0; border-radius: 10px; padding: 14px; font: inherit; font-weight: 700; font-size: 15px; cursor: pointer; }
.adv-submit:hover { background: #0d9668; }
.adv-submit[disabled] { opacity: .6; cursor: wait; }
.adv-cancel { background: none; border: 0; font: inherit; font-size: 13px; color: #55627a; text-decoration: underline; cursor: pointer; }
.adv-msg { border-radius: 10px; padding: 12px 14px; font-size: 14px; display: none; }
.adv-msg.ok { display: block; background: #f2fbf7; border: 1px solid #c4ecd9; color: #14684b; }
.adv-msg.err { display: block; background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }
.adv-fineprint { font-size: 12px; color: #55627a; }

/* queue */
.queue { border: 1px solid var(--line, #e5eaf0); border-radius: 14px; overflow: hidden; background: #fff; }
.queue .qhead { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; border-bottom: 1px solid #eef2f5; font-size: 11px; font-weight: 700; letter-spacing: .08em; color: #55627a; }
.queue .qrow { display: flex; align-items: center; gap: 12px; padding: 10px 16px; border-bottom: 1px solid #f2f5f8; font-size: 13.5px; }
.queue .qrow:last-child { border-bottom: 0; }
.queue .qbid { font-weight: 700; white-space: nowrap; }
.queue .qico { width: 26px; height: 26px; border-radius: 7px; background: linear-gradient(135deg,#4ade80,#2dd4bf); flex: none; object-fit: cover; }
.queue .qline { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.queue .qline small { color: #55627a; }
.queue .qempty { padding: 22px 16px; font-size: 14px; color: #55627a; }
.chipst { font-size: 11px; font-weight: 700; border-radius: 999px; padding: 3px 10px; white-space: nowrap; }
.st-pending_review { background: #fef9c3; color: #854d0e; }
.st-approved, .st-live { background: #dcfce7; color: #14684b; }
.st-paused { background: #e2e8f0; color: #334155; }
.st-rejected { background: #fee2e2; color: #991b1b; }

/* portal */
.portal-hero { background: #f2faf7; border: 1px solid #d9efe4; border-radius: 18px; padding: 28px 30px; display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
.portal-hero h1 { font-size: 28px; letter-spacing: -0.015em; }
.portal-hero p { color: #55627a; font-size: 14px; margin-top: 6px; max-width: 60ch; }
.stat-cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin: 18px 0; }
.stat { background: #fff; border: 1px solid var(--line, #e5eaf0); border-radius: 12px; padding: 14px 16px; }
.stat .k { font-size: 10.5px; font-weight: 700; letter-spacing: .08em; color: #55627a; text-transform: uppercase; }
.stat .v { font-size: 24px; font-weight: 800; margin-top: 2px; }
.stat .s { font-size: 11.5px; color: #55627a; }
.report-cards { display: flex; gap: 16px; flex-wrap: wrap; }
.report { width: 250px; border: 1px solid var(--line, #e5eaf0); border-radius: 14px; background: #fff; overflow: hidden; }
.report .rhead { display: flex; justify-content: space-between; align-items: center; padding: 10px 14px; font-size: 13.5px; font-weight: 700; }
.report .rcreative { margin: 0 14px; background: #0f172a; border-radius: 10px; padding: 14px; color: #e2e8f0; }
.report .rcreative .tag { font-size: 8.5px; letter-spacing: .12em; color: #64748b; margin-bottom: 8px; }
.report .rcreative .row { display: flex; gap: 8px; align-items: center; font-weight: 700; color: #fff; font-size: 14px; }
.report .rcreative img, .report .rcreative .ph { width: 26px; height: 26px; border-radius: 7px; background: linear-gradient(135deg,#4ade80,#2dd4bf); }
.report .rcreative .cta { display: inline-block; margin-top: 10px; font-size: 11px; font-weight: 700; border: 1px solid #34d399; color: #6ee7b7; border-radius: 999px; padding: 3px 10px; }
.report .rstats { display: flex; justify-content: space-between; padding: 12px 14px; font-size: 11px; color: #55627a; }
.report .rstats b { display: block; font-size: 15px; color: #0b1424; }
.ctable { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.ctable th { text-align: left; font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: #55627a; padding: 10px 12px; border-bottom: 1px solid var(--line, #e5eaf0); }
.ctable td { padding: 12px; border-bottom: 1px solid #f2f5f8; vertical-align: top; }
.ctable .act { background: none; border: 1px solid #d7dee6; border-radius: 7px; padding: 4px 10px; font: inherit; font-size: 12px; cursor: pointer; margin: 0 4px 4px 0; }
.ctable .act:hover { border-color: #94a3b8; }
.ctable .act.danger { color: #b91c1c; border-color: #fecaca; }
@media (max-width: 900px) { .stat-cards { grid-template-columns: repeat(2, 1fr); } .adv-two, .adv-placements { grid-template-columns: 1fr; } }
