.campaign-create-dialog { width: min(1040px, calc(100vw - 32px)); max-height: min(780px, calc(100vh - 32px)); padding: 0; color: var(--text); border: 1px solid var(--line); border-radius: var(--radius); background: #ffffff; box-shadow: var(--shadow); }
.campaign-create-dialog::backdrop { background: rgba(12, 20, 31, .42); backdrop-filter: blur(6px); }
.campaign-wizard-form { display: grid; grid-template-rows: auto minmax(0, 1fr) auto; max-height: inherit; }
.campaign-wizard-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 20px; border-bottom: 1px solid var(--line); background: linear-gradient(180deg, #ffffff, #f8fbff); }
.campaign-wizard-head span, .wizard-title p, .wizard-recommend span, .campaign-summary span { color: var(--muted); font-size: 12px; font-weight: 900; }
.campaign-wizard-head strong { display: block; margin-top: 4px; color: var(--ink); font-size: 19px; }
.icon-close { display: grid; place-items: center; width: 34px; height: 34px; color: #506276; border: 1px solid var(--line); border-radius: var(--radius); background: #ffffff; font-size: 20px; line-height: 1; }
.campaign-wizard-head-actions { display: flex; align-items: center; gap: 10px; }
.campaign-wizard-head-actions .notify-button { position: relative; width: 38px; height: 38px; border: 0; border-radius: 999px; background: transparent; color: #17263a; }
.campaign-wizard-head-actions .notify-button::after { content: attr(data-count); position: absolute; top: 2px; right: 5px; width: 17px; height: 17px; border-radius: 999px; background: #ff3040; color: #fff; font-size: 10px; font-weight: 950; line-height: 17px; text-align: center; }
.campaign-wizard-head-actions .avatar { display: inline-flex; align-items: center; gap: 8px; height: 38px; border: 1px solid rgba(35, 49, 72, .12); border-radius: 999px; padding: 0 13px 0 7px; background: #fff; color: #40546a; font-size: 12px; font-weight: 900; }
.campaign-wizard-head-actions .avatar span { width: 24px; height: 24px; border-radius: 999px; background: linear-gradient(135deg, #2cd083, #29abe2); }
.campaign-wizard-head-actions .compact { height: 38px; border-radius: 12px; padding: 0 14px; background: #fff; color: #31465a; font-size: 12px; font-weight: 900; }
.campaign-wizard { display: grid; grid-template-columns: 118px minmax(0, 1fr) 244px; min-height: 500px; overflow: hidden; }
.campaign-steps { display: grid; align-content: start; gap: 8px; padding: 18px 14px; border-right: 1px solid var(--line); background: #f8fbff; }
.campaign-steps button { display: grid; grid-template-columns: 28px minmax(0, 1fr); align-items: center; gap: 8px; min-height: 42px; padding: 7px; text-align: left; color: #5a6b7d; border: 1px solid transparent; border-radius: var(--radius); background: transparent; font-weight: 900; }
.campaign-steps b { display: grid; place-items: center; width: 28px; height: 28px; color: #63758a; border: 1px solid var(--line); border-radius: 50%; background: #ffffff; font-size: 12px; }
.campaign-steps .active { color: #006e8c; border-color: #98d8ee; background: var(--cyan-soft); }
.campaign-steps .active b, .campaign-steps .done b { color: #ffffff; border-color: transparent; background: var(--cyan); }
.campaign-steps .done { color: #198d67; }
.wizard-panels { min-width: 0; overflow: auto; padding: 22px; }
.wizard-panel { display: grid; gap: 15px; }
.wizard-panel[hidden] { display: none !important; }
.wizard-title h2 { margin: 0; color: var(--ink); font-size: 22px; line-height: 1.2; }
.wizard-title p { margin: 8px 0 0; line-height: 1.6; }
.campaign-wizard label, .campaign-wizard fieldset { display: grid; gap: 8px; min-width: 0; }
.campaign-wizard label span, .campaign-wizard legend { color: #47586b; font-size: 12px; font-weight: 900; }
.campaign-wizard input[type="text"], .campaign-wizard input:not([type]), .campaign-wizard select, .campaign-wizard textarea { width: 100%; min-height: 42px; padding: 10px 12px; color: var(--text); border: 1px solid var(--line); border-radius: var(--radius); outline: 0; background: #fbfdff; font-size: 13px; }
.campaign-wizard textarea { min-height: 108px; resize: vertical; line-height: 1.65; }
.campaign-wizard input:focus, .campaign-wizard select:focus, .campaign-wizard textarea:focus { border-color: #91d7f0; box-shadow: 0 0 0 3px rgba(8, 168, 216, .12); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.choice-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; padding: 0; border: 0; }
.choice-grid legend { grid-column: 1 / -1; margin-bottom: 2px; }
.choice-grid label { display: flex; align-items: center; gap: 9px; min-height: 44px; padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--radius); background: #ffffff; font-size: 13px; font-weight: 900; }
.choice-grid input, .template-option input { width: 16px; height: 16px; accent-color: var(--cyan); }
.template-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.template-option { position: relative; display: block; }
.template-option input { position: absolute; top: 12px; right: 12px; }
.template-option span { display: block; min-height: 154px; padding: 14px; border: 1px solid var(--line); border-radius: var(--radius); background: #ffffff; }
.template-option input:checked + span { border-color: #8bd8ef; background: var(--cyan-soft); box-shadow: 0 10px 24px rgba(8, 168, 216, .12); }
.template-option strong, .template-option small, .template-option em { display: block; }
.template-option strong { padding-right: 24px; color: var(--ink); font-size: 14px; }
.template-option small { margin-top: 8px; color: var(--muted); font-size: 12px; font-weight: 900; }
.template-option em { margin-top: 12px; color: #4e6275; font-size: 12px; font-style: normal; line-height: 1.55; }
.campaign-summary { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 9px; }
.campaign-summary article { min-width: 0; padding: 12px; border: 1px solid var(--line); border-radius: var(--radius); background: #f8fbff; }
.campaign-summary strong { display: block; min-width: 0; margin-top: 7px; overflow: hidden; color: var(--ink); font-size: 13px; line-height: 1.45; text-overflow: ellipsis; }
.campaign-summary b { font: inherit; }
.wizard-recommend { padding: 20px 18px; border-left: 1px solid var(--line); background: #f8fbff; }
.wizard-recommend ol { display: grid; gap: 10px; margin: 14px 0; padding-left: 18px; color: #344658; font-size: 13px; font-weight: 800; line-height: 1.55; }
.wizard-recommend p { margin: 0; padding: 12px; color: #51677b; border-radius: var(--radius); background: #ffffff; font-size: 12px; line-height: 1.65; }
.campaign-wizard-foot { display: flex; align-items: center; justify-content: flex-end; gap: 10px; padding: 14px 20px; border-top: 1px solid var(--line); background: #ffffff; }
@media (min-width: 921px) { .campaign-create-dialog { position: fixed; inset: 0 0 0 204px; width: calc(100vw - 204px); max-width: none; height: 100dvh; max-height: 100dvh; margin: 0; border: 0; border-radius: 24px 0 0 24px; background: radial-gradient(circle at 76% 3%, rgba(52, 236, 211, .18), transparent 24%), radial-gradient(circle at 60% -8%, rgba(108, 75, 255, .16), transparent 30%), linear-gradient(180deg, #f8fbff 0%, #f4f7fc 48%, #eef4fb 100%); box-shadow: none; }
.campaign-create-dialog::backdrop { background: transparent; backdrop-filter: none; }
body:has(.campaign-create-dialog[open]) { overflow: hidden; }
body:has(.campaign-create-dialog[open]) .app-shell { height: 100vh; min-height: 0; max-height: 100vh; overflow: hidden; }
body:has(.campaign-create-dialog[open]) .workspace { min-height: 0; max-height: 100vh; overflow: hidden; }
.campaign-wizard-form { height: 100vh; max-height: none; grid-template-rows: auto minmax(0, 1fr) auto; }
.campaign-wizard-head { min-height: 112px; padding: 26px 28px 10px; border-bottom: 0; background: transparent; }
.campaign-wizard-head strong { margin: 0; color: #111827; font-size: 29px; line-height: 1.12; font-weight: 950; letter-spacing: 0; }
.campaign-wizard-head strong em { margin: 0 8px; color: #111827; font-style: normal; font-weight: 850; }
.campaign-wizard-head span { display: block; margin-top: 12px; color: #536179; font-size: 16px; font-weight: 650; }
.campaign-create-dialog .icon-close { display: none !important; }
.campaign-wizard { display: grid; grid-template-columns: minmax(0, 1fr) 300px; grid-template-rows: 72px minmax(0, 1fr); gap: 8px 18px; min-height: 0; padding: 0 28px; overflow: hidden; }
.campaign-steps { grid-column: 1; grid-row: 1; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0; align-items: start; padding: 2px 54px 0; border: 0; background: transparent; }
.campaign-steps button { position: relative; display: grid; justify-items: center; gap: 8px; min-height: 60px; padding: 0; color: #2f3e55; border: 0; background: transparent; text-align: center; }
.campaign-steps button::before { content: ""; position: absolute; top: 16px; left: calc(-50% + 21px); width: calc(100% - 42px); height: 3px; border-radius: 999px; background: #cfd8e7; }
.campaign-steps button:first-child::before { content: none; }
.campaign-steps .active::before, .campaign-steps .done::before { background: linear-gradient(90deg, #16c6a4, #426cff); }
.campaign-steps b { z-index: 1; width: 34px; height: 34px; color: #344054; border-color: #cfd8e7; background: rgba(255, 255, 255, .92); box-shadow: 0 6px 14px rgba(36, 52, 83, .08); font-size: 15px; }
.campaign-steps span { color: #2f3e55; font-size: 14px; font-weight: 900; }
.campaign-steps .active { color: #16aa83; border: 0; background: transparent; }
.campaign-steps .active span, .campaign-steps .done span { color: #13a97f; }
.campaign-steps .active b, .campaign-steps .done b { background: linear-gradient(135deg, #20c99f, #28b8d8); }
.wizard-panels { grid-column: 1; grid-row: 2; overflow: auto; padding: 0; }
.wizard-panel[data-wizard-step="1"] { gap: 12px; }
.wizard-panel[data-wizard-step="1"] > .wizard-title, .campaign-choice-grid, .campaign-template-strip, .campaign-selection-bar { border: 1px solid rgba(204, 214, 235, .84); border-radius: 14px; background: rgba(255, 255, 255, .78); box-shadow: 0 14px 34px rgba(36, 52, 83, .06); }
.wizard-panel[data-wizard-step="1"] > .wizard-title { display: none; }
.wizard-panel[data-wizard-step="1"] > label { display: none; }
.campaign-choice-grid { display: grid; gap: 8px; margin: 0; padding: 13px 22px; min-width: 0; }
.campaign-choice-grid legend { grid-column: 1 / -1; margin-bottom: 0; color: #111827; font-size: 18px; font-weight: 950; }
.campaign-choice-grid legend small { margin-left: 10px; color: #768199; font-size: 13px; font-weight: 750; }
.industry-grid legend { display: flex; align-items: center; justify-content: space-between; gap: 12px; width: 100%; }
.industry-guide-link { display: inline-flex; align-items: center; gap: 4px; padding: 0; color: #386dff; border: 0; background: transparent; font-size: 13px; font-weight: 850; }
.industry-guide-link i { width: 13px; height: 13px; font-style: normal; font-weight: 950; }
.industry-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.goal-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.campaign-choice-card { min-width: 0; }
.campaign-choice-card input { position: absolute; opacity: 0; pointer-events: none; }
.campaign-choice-card span { position: relative; display: grid; place-items: center; min-height: 86px; padding: 11px; color: #1e2b3f; border: 1px solid rgba(207, 216, 231, .92); border-radius: 12px; background: linear-gradient(180deg, rgba(255, 255, 255, .95), rgba(250, 253, 255, .78)); box-shadow: 0 10px 26px rgba(36, 52, 83, .035); }
.campaign-choice-card i { margin-bottom: 8px; color: #315dff; transform: scale(1.16); }
.campaign-create-dialog .industry-choice .industry-choice-icon.aiv-icon { width: 42px; height: 42px; margin-bottom: 8px; color: var(--industry-choice-color, #315dff); filter: drop-shadow(0 8px 14px rgba(49, 93, 255, .12)); transform: none; }
.industry-choice .industry-choice-icon .aiv-svg { stroke-width: 2.15; }
.campaign-choice-card strong { font-size: 15px; font-weight: 950; }
.campaign-choice-card small { margin-top: 8px; color: #8390a5; font-size: 12px; font-weight: 750; }
.campaign-choice-card input:checked + span { border-color: #20c6a6; background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(237, 255, 249, .86)); box-shadow: 0 0 0 1px rgba(32, 198, 166, .42), 0 16px 34px rgba(32, 198, 166, .12); }
.campaign-choice-card input:checked + span::after { content: "✓"; position: absolute; top: -10px; right: -10px; display: grid; place-items: center; width: 28px; height: 28px; color: #ffffff; border-radius: 50%; background: #20c6a6; box-shadow: 0 10px 20px rgba(32, 198, 166, .28); font-weight: 950; }
.goal-choice span { min-height: 54px; align-content: center; }
.campaign-template-strip { padding: 12px 18px 14px; }
.campaign-template-strip header { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 12px; }
.campaign-template-strip h3, .campaign-template-strip p { margin: 0; }
.campaign-template-strip h3 { color: #111827; font-size: 16px; font-weight: 950; }
.campaign-template-strip p { margin-top: 5px; color: #768199; font-size: 13px; font-weight: 750; }
.campaign-template-row { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 12px; }
.campaign-template-card { position: relative; overflow: hidden; min-height: 128px; border: 1px solid rgba(204, 214, 235, .82); border-radius: 12px; background: #ffffff; }
.campaign-template-card img { width: 100%; height: 68px; object-fit: cover; }
.campaign-template-card b, .campaign-template-card small { display: block; padding: 0 10px; }
.campaign-template-card b { margin-top: 9px; color: #1e2b3f; font-size: 12px; font-weight: 950; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.campaign-template-card small { margin-top: 6px; color: #6f7c94; font-size: 11px; font-weight: 750; }
.campaign-template-card > i { position: absolute; left: 10px; top: 62px; display: grid; place-items: center; width: 24px; height: 24px; color: #ffffff; border-radius: 50%; background: rgba(17, 24, 39, .72); }
.campaign-template-card button { position: absolute; right: 8px; top: 58px; display: grid; place-items: center; width: 28px; height: 28px; color: #506276; border: 1px solid rgba(204, 214, 235, .8); border-radius: 50%; background: rgba(255, 255, 255, .92); font-size: 22px; }
.campaign-selection-bar { display: none; align-items: center; gap: 44px; min-height: 70px; padding: 0 28px; color: #66758e; font-size: 14px; font-weight: 850; }
.campaign-selection-bar b { display: inline-flex; margin-left: 8px; padding: 8px 14px; color: #10a87c; border-radius: 10px; background: rgba(221, 252, 241, .9); font-weight: 950; }
.wizard-recommend { grid-column: 2; grid-row: 1 / 3; overflow: auto; display: grid; align-content: start; gap: 14px; padding: 18px; border: 1px solid rgba(204, 214, 235, .84); border-radius: 14px; background: rgba(255, 255, 255, .72); box-shadow: 0 14px 34px rgba(36, 52, 83, .06); }
.wizard-recommend header { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.wizard-recommend h2 { margin: 0; color: #111827; font-size: 18px; font-weight: 950; }
.wizard-recommend header span, .wizard-recommend small { color: #768199; font-size: 12px; font-weight: 850; }
.wizard-recommend section { padding: 14px; border: 1px solid rgba(204, 214, 235, .82); border-radius: 12px; background: rgba(255, 255, 255, .76); }
.ai-choice-card strong { display: flex; align-items: center; gap: 10px; min-height: 54px; margin: 8px 0 16px; padding: 0 14px; color: #1d293d; border: 1px solid rgba(204, 214, 235, .86); border-radius: 10px; background: rgba(248, 251, 255, .9); font-size: 14px; font-weight: 950; }
.campaign-create-dialog .ai-choice-card .industry-choice-icon.aiv-icon { flex: 0 0 auto; width: 28px; height: 28px; color: var(--industry-choice-color, #111827); }
.ai-choice-card .industry-choice-icon .aiv-svg { stroke-width: 2.15; }
.ai-choice-card em { display: inline-flex; margin-top: 8px; padding: 8px 12px; color: #10a87c; border-radius: 9px; background: rgba(221, 252, 241, .9); font-style: normal; font-weight: 950; }
.ai-channel-list { display: grid; gap: 8px; }
.ai-channel-list p { display: grid; grid-template-columns: 20px minmax(0, 1fr) auto; align-items: center; gap: 8px; margin: 0; padding: 9px 10px; color: #263447; border: 1px solid rgba(204, 214, 235, .78); border-radius: 9px; background: #ffffff; }
.ai-channel-list i { display: grid; place-items: center; width: 20px; height: 20px; border-radius: 6px; background-color: #111827; background-position: center; background-repeat: no-repeat; background-size: 12px 12px; }
.ai-channel-list [data-platform="douyin"] { background-image: url("../aivideo_final_premium_site/assets/generated/platform-icons/douyin.svg"); }
.ai-channel-list [data-platform="xhs"] { background-color: #ff2442; background-image: url("../aivideo_final_premium_site/assets/generated/platform-icons/xhs.svg"); }
.ai-channel-list [data-platform="wechat_channels"] { background-color: #ff8a00; background-image: url("../aivideo_final_premium_site/assets/generated/platform-icons/wechat-channels.svg"); }
.ai-channel-list [data-platform="meituan"] { background-color: #ff7a1a; }
.ai-channel-list [data-platform="meituan"]::before { content: "美"; color: #fff; font-size: 11px; font-style: normal; font-weight: 950; }
.ai-channel-list b { font-size: 13px; font-weight: 950; }
.ai-channel-list span { color: #7c879a; font-size: 11px; font-weight: 800; }
.ai-estimate-card strong { display: block; margin-top: 8px; color: #111827; font-size: 30px; line-height: 1; font-weight: 950; }
.ai-estimate-card strong span { font-size: 13px; }
.ai-estimate-card em { display: block; margin-top: 10px; color: #10a87c; font-size: 22px; font-style: normal; font-weight: 950; }
.ai-estimate-card p, .ai-boost-card p { margin: 7px 0 0; padding: 0; color: #738199; background: transparent; font-size: 12px; font-weight: 800; line-height: 1.45; }
.ai-boost-card { display: grid; gap: 10px; }
.ai-boost-card p { display: flex; align-items: center; gap: 9px; margin: 0; color: #526178; }
.ai-boost-card i { color: #566bff; }
.campaign-wizard-foot { min-height: 76px; margin: 0 28px 18px; padding: 0 18px; border: 1px solid rgba(204, 214, 235, .84); border-radius: 14px; background: rgba(255, 255, 255, .78); box-shadow: 0 14px 34px rgba(36, 52, 83, .06); }
.campaign-footer-selection, .campaign-footer-actions { display: flex; align-items: center; gap: 14px; }
.campaign-footer-selection { margin-right: auto; color: #66758e; font-size: 14px; font-weight: 850; }
.campaign-footer-selection b { display: inline-flex; margin-left: 8px; padding: 8px 14px; color: #10a87c; border-radius: 10px; background: rgba(221, 252, 241, .9); font-weight: 950; }
.campaign-footer-actions [data-close-dialog], .campaign-footer-actions [data-prev-step], .campaign-footer-actions [data-save-campaign-draft] { display: none; }
.campaign-wizard-foot .outline-button { min-width: 86px; }
.campaign-wizard-foot .primary-button { min-width: 400px; min-height: 50px; border-radius: 12px; background: linear-gradient(135deg, #8d3cff, #096eff); box-shadow: 0 14px 30px rgba(55, 91, 255, .24); font-size: 16px; }
}
@media (max-width: 920px) { .campaign-wizard { grid-template-columns: 1fr; min-height: 0; }
.campaign-steps { grid-template-columns: repeat(4, minmax(0, 1fr)); padding: 12px; border-right: 0; border-bottom: 1px solid var(--line); }
.campaign-steps button { grid-template-columns: 1fr; justify-items: center; text-align: center; }
.campaign-steps span { font-size: 12px; }
.wizard-recommend { border-left: 0; border-top: 1px solid var(--line); }
.template-grid, .campaign-summary { grid-template-columns: 1fr; }
}
@media (max-width: 620px) { .campaign-create-dialog { width: 100vw; max-height: 100vh; border-radius: 0; }
.campaign-wizard-head, .wizard-panels, .wizard-recommend, .campaign-wizard-foot { padding-left: 14px; padding-right: 14px; }
.campaign-wizard-head strong { font-size: 17px; }
.wizard-title h2 { font-size: 19px; }
.form-grid, .choice-grid { grid-template-columns: 1fr; }
.campaign-wizard-foot { display: grid; grid-template-columns: 1fr 1fr; }
.campaign-wizard-foot .primary-button, .campaign-wizard-foot .outline-button { width: 100%; }
}
