@use "./variables.scss" as *; @use "sass:color"; .callout { border: 1px solid var(--border); background-color: var(--bg); border-radius: 5px; padding: 0 1rem; overflow-y: hidden; transition: max-height 0.3s ease; box-sizing: border-box; & > *:nth-child(2) { margin-top: 0; } --callout-icon-note: url('data:image/svg+xml; utf8, '); --callout-icon-abstract: url('data:image/svg+xml; utf8, '); --callout-icon-info: url('data:image/svg+xml; utf8, '); --callout-icon-todo: url('data:image/svg+xml; utf8, '); --callout-icon-tip: url('data:image/svg+xml; utf8, '); --callout-icon-success: url('data:image/svg+xml; utf8, '); --callout-icon-question: url('data:image/svg+xml; utf8, '); --callout-icon-warning: url('data:image/svg+xml; utf8, '); --callout-icon-failure: url('data:image/svg+xml; utf8, '); --callout-icon-danger: url('data:image/svg+xml; utf8, '); --callout-icon-bug: url('data:image/svg+xml; utf8, '); --callout-icon-example: url('data:image/svg+xml; utf8, '); --callout-icon-quote: url('data:image/svg+xml; utf8, '); --callout-icon-fold: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"%3E%3Cpolyline points="6 9 12 15 18 9"%3E%3C/polyline%3E%3C/svg%3E'); &[data-callout] { --color: #448aff; --border: #448aff44; --bg: #448aff10; --callout-icon: var(--callout-icon-note); } &[data-callout="abstract"] { --color: #00b0ff; --border: #00b0ff44; --bg: #00b0ff10; --callout-icon: var(--callout-icon-abstract); } &[data-callout="info"], &[data-callout="todo"] { --color: #00b8d4; --border: #00b8d444; --bg: #00b8d410; --callout-icon: var(--callout-icon-info); } &[data-callout="todo"] { --callout-icon: var(--callout-icon-todo); } &[data-callout="tip"] { --color: #00bfa5; --border: #00bfa544; --bg: #00bfa510; --callout-icon: var(--callout-icon-tip); } &[data-callout="success"] { --color: #09ad7a; --border: #09ad7144; --bg: #09ad7110; --callout-icon: var(--callout-icon-success); } &[data-callout="question"] { --color: #dba642; --border: #dba64244; --bg: #dba64210; --callout-icon: var(--callout-icon-question); } &[data-callout="warning"] { --color: #db8942; --border: #db894244; --bg: #db894210; --callout-icon: var(--callout-icon-warning); } &[data-callout="failure"], &[data-callout="danger"], &[data-callout="bug"] { --color: #db4242; --border: #db424244; --bg: #db424210; --callout-icon: var(--callout-icon-failure); } &[data-callout="bug"] { --callout-icon: var(--callout-icon-bug); } &[data-callout="danger"] { --callout-icon: var(--callout-icon-danger); } &[data-callout="example"] { --color: #7a43b5; --border: #7a43b544; --bg: #7a43b510; --callout-icon: var(--callout-icon-example); } &[data-callout="quote"] { --color: var(--secondary); --border: var(--lightgray); --callout-icon: var(--callout-icon-quote); } &.is-collapsed > .callout-title > .fold-callout-icon { transform: rotateZ(-90deg); } } .callout-title { display: flex; align-items: flex-start; gap: 5px; padding: 1rem 0; color: var(--color); --icon-size: 18px; & .fold-callout-icon { transition: transform 0.15s ease; opacity: 0.8; cursor: pointer; --callout-icon: var(--callout-icon-fold); } & > .callout-title-inner > p { color: var(--color); margin: 0; } .callout-icon, & .fold-callout-icon { width: var(--icon-size); height: var(--icon-size); flex: 0 0 var(--icon-size); // icon support background-size: var(--icon-size) var(--icon-size); background-position: center; background-color: var(--color); mask-image: var(--callout-icon); mask-size: var(--icon-size) var(--icon-size); mask-position: center; mask-repeat: no-repeat; padding: 0.2rem 0; } .callout-title-inner { font-weight: $boldWeight; } }