.abc-shell {
--abc-bg: #f5efe6;
--abc-panel: rgba(255, 252, 247, 0.96);
--abc-line: #d8cab7;
--abc-text: #2d241c;
--abc-muted: #6f6255;
--abc-brand: #0f766e;
--abc-brand-strong: #115e59;
--abc-brand-soft: #d7f3ee;
--abc-user: #1f2937;
--abc-warning: #b45309;
--abc-warning-soft: #fff7ed;
--abc-error: #b91c1c;
--abc-error-soft: #fef2f2;
--abc-success: #166534;
--abc-success-soft: #f0fdf4;
--abc-shadow: 0 24px 60px rgba(66, 44, 21, 0.12);
display: grid;
grid-template-columns: 1.02fr 0.98fr;
gap: 22px;
width: min(1180px, 100%);
margin: 0 auto;
color: var(--abc-text);
font-family: "Hiragino Sans", "Yu Gothic", sans-serif;
}
.abc-shell * {
box-sizing: border-box;
}
.abc-hero,
.abc-widget {
background: var(--abc-panel);
border: 1px solid var(--abc-line);
border-radius: 28px;
box-shadow: var(--abc-shadow);
}
.abc-hero {
padding: 32px;
background:
radial-gradient(circle at top left, rgba(15, 118, 110, 0.16), transparent 28%),
radial-gradient(circle at right 20%, rgba(194, 65, 12, 0.1), transparent 20%),
linear-gradient(180deg, #fbf6ef 0%, var(--abc-bg) 100%);
}
.abc-eyebrow {
display: inline-flex;
padding: 8px 12px;
border-radius: 999px;
background: #fff;
border: 1px solid var(--abc-line);
font-size: 13px;
font-weight: 700;
color: var(--abc-brand-strong);
}
.abc-heading {
margin: 18px 0 14px;
font-size: clamp(32px, 5vw, 52px);
line-height: 1.05;
}
.abc-lead {
margin: 0;
font-size: 16px;
line-height: 1.8;
color: var(--abc-muted);
}
.abc-alert {
margin-top: 20px;
padding: 16px 18px;
border-radius: 18px;
background: #fff;
border: 1px solid #f2c58a;
}
.abc-alert strong {
display: block;
margin-bottom: 6px;
color: var(--abc-warning);
}
.abc-alert p {
margin: 0;
line-height: 1.7;
color: var(--abc-text);
}
.abc-feature-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 12px;
margin-top: 24px;
}
.abc-feature {
padding: 16px;
border-radius: 18px;
background: rgba(255, 255, 255, 0.82);
border: 1px solid var(--abc-line);
}
.abc-feature strong {
display: block;
margin-bottom: 4px;
}
.abc-feature span {
color: var(--abc-muted);
font-size: 13px;
line-height: 1.6;
}
.abc-widget {
overflow: hidden;
display: flex;
flex-direction: column;
min-height: 820px;
}
.abc-widget-header {
padding: 20px 22px 16px;
background: linear-gradient(135deg, #0f766e 0%, #115e59 100%);
color: #fff;
}
.abc-progress-head {
display: flex;
justify-content: space-between;
align-items: flex-start;
gap: 16px;
}
.abc-progress-step,
.abc-progress-percent,
.abc-sublead {
margin: 0;
}
.abc-progress-step {
font-size: 14px;
font-weight: 700;
}
.abc-progress-percent {
margin-top: 4px;
font-size: 12px;
color: rgba(255, 255, 255, 0.84);
}
.abc-progress-bar {
margin-top: 14px;
width: 100%;
height: 10px;
border-radius: 999px;
background: rgba(255, 255, 255, 0.16);
overflow: hidden;
}
.abc-progress-bar span {
display: block;
width: 0;
height: 100%;
border-radius: inherit;
background: linear-gradient(90deg, #fef3c7 0%, #f59e0b 100%);
transition: width 0.25s ease;
}
.abc-sublead {
margin-top: 12px;
line-height: 1.7;
font-size: 14px;
color: rgba(255, 255, 255, 0.88);
}
.abc-chat {
flex: 1;
overflow-y: auto;
padding: 18px;
background:
linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(255, 249, 242, 0.96)),
repeating-linear-gradient(135deg, rgba(216, 202, 183, 0.12) 0 12px, rgba(255, 255, 255, 0) 12px 24px);
}
.abc-message {
display: flex;
gap: 10px;
margin-bottom: 14px;
}
.abc-message[data-role="user"] {
justify-content: flex-end;
}
.abc-avatar {
width: 38px;
height: 38px;
flex-shrink: 0;
display: grid;
place-items: center;
border-radius: 14px;
font-size: 14px;
font-weight: 700;
}
.abc-avatar.bot {
background: var(--abc-brand-soft);
}
.abc-avatar.user {
background: #e5e7eb;
}
.abc-bubble {
max-width: 92%;
padding: 14px 16px;
border-radius: 18px;
border: 1px solid var(--abc-line);
background: #fff;
line-height: 1.75;
font-size: 14px;
white-space: normal;
}
.abc-message[data-role="user"] .abc-bubble {
background: var(--abc-user);
color: #fff;
border-color: var(--abc-user);
}
.abc-choice-grid {
display: grid;
gap: 10px;
margin-top: 10px;
}
.abc-choice {
padding: 14px;
border-radius: 16px;
border: 1px solid var(--abc-line);
background: #fff;
color: var(--abc-text);
text-align: left;
cursor: pointer;
font: inherit;
transition: transform 0.18s ease, border-color 0.18s ease;
}
.abc-choice:hover,
.abc-primary:hover,
.abc-secondary:hover,
.abc-start-top:hover {
transform: translateY(-1px);
}
.abc-choice:disabled {
opacity: 0.6;
cursor: default;
}
.abc-card-form {
display: grid;
gap: 14px;
}
.abc-field {
display: grid;
gap: 6px;
}
.abc-field-label {
font-size: 12px;
font-weight: 700;
color: var(--abc-muted);
}
.abc-input {
width: 100%;
border: 1px solid var(--abc-line);
border-radius: 14px;
padding: 13px 14px;
background: #fff;
color: var(--abc-text);
font: inherit;
}
textarea.abc-input {
min-height: 96px;
resize: vertical;
}
.abc-input:focus {
outline: 2px solid rgba(15, 118, 110, 0.16);
border-color: var(--abc-brand);
}
.abc-preference-row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 10px;
}
.abc-hint {
margin: -4px 0 0;
font-size: 12px;
line-height: 1.6;
color: var(--abc-muted);
}
.abc-actions {
display: flex;
flex-wrap: wrap;
gap: 10px;
margin-top: 12px;
}
.abc-primary,
.abc-secondary,
.abc-start-top {
border: 0;
border-radius: 16px;
padding: 12px 16px;
font: inherit;
font-weight: 700;
cursor: pointer;
}
.abc-primary,
.abc-start-top {
background: var(--abc-brand);
color: #fff;
}
.abc-secondary {
background: #fff;
color: var(--abc-text);
border: 1px solid var(--abc-line);
}
.abc-start-top:disabled {
opacity: 0.6;
cursor: default;
}
.abc-note {
margin-top: 10px;
padding: 14px;
border-radius: 16px;
border: 1px solid var(--abc-line);
background: #fafaf9;
}
.abc-note p {
margin: 0 0 8px;
}
.abc-note p:last-child {
margin-bottom: 0;
}
.abc-note.warning {
background: var(--abc-warning-soft);
border-color: #fdba74;
color: #7c2d12;
}
.abc-note.error {
background: var(--abc-error-soft);
border-color: #fca5a5;
color: var(--abc-error);
}
.abc-note.success {
background: var(--abc-success-soft);
border-color: #86efac;
color: var(--abc-success);
}
.abc-note.soft {
background: #eff6ff;
border-color: #93c5fd;
color: #1d4ed8;
}
.abc-summary,
.abc-clinic-card {
margin-top: 10px;
padding: 14px;
background: #fff7ed;
border: 1px solid #fdba74;
border-radius: 16px;
line-height: 1.8;
}
.abc-composer {
padding: 16px 18px 18px;
background: rgba(255, 255, 255, 0.85);
border-top: 1px solid var(--abc-line);
}
.abc-status {
margin: 0;
font-size: 12px;
line-height: 1.6;
color: var(--abc-muted);
}
@media (max-width: 980px) {
.abc-shell {
grid-template-columns: 1fr;
}
.abc-widget {
min-height: 720px;
}
}
@media (max-width: 640px) {
.abc-hero,
.abc-widget {
border-radius: 22px;
}
.abc-hero {
padding: 22px 18px;
}
.abc-feature-grid,
.abc-preference-row,
.abc-progress-head {
grid-template-columns: 1fr;
display: grid;
}
.abc-progress-head {
gap: 12px;
}
.abc-start-top {
width: 100%;
}
.abc-bubble {
max-width: 100%;
}
}