@use "sass:string";

@function gtkalpha($c, $a) {
    @return string.unquote("alpha(#{$c},#{$a})");
}

// https://gitlab.gnome.org/GNOME/gtk/-/blob/gtk-3-24/gtk/theme/Adwaita/_colors-public.scss
$fg-color: #{"@theme_fg_color"};
$bg-color: #1f2430;
$error: red;

window.NotificationPopups {
    all: unset;
}

eventbox.Notification {

    &:first-child>box {
        margin-top: 1rem;
    }

    &:last-child>box {
        margin-bottom: 1rem;
    }

    // eventboxes can not take margins so we style its inner box instead
    >box {
        min-width: 400px;
        border-radius: 13px;
        background-color: #1f2430;
        margin: .5rem 1rem .5rem 1rem;
        box-shadow: 2px 3px 8px 0 gtkalpha(black, .4);
        border: 1pt solid gtkalpha($fg-color, .03);
    }

    &.critical>box {
        border: 1pt solid gtkalpha($error, .4);

        .header {

            .app-name {
                color: gtkalpha($error, .8);

            }

            .app-icon {
                color: gtkalpha($error, .6);
            }
        }
    }

    .header {
        padding: .5rem;
        color: gtkalpha($fg-color, 0.5);

        .app-icon {
            margin: 0 .4rem;
        }

        .app-name {
            margin-right: .3rem;
            font-weight: bold;

            &:first-child {
                margin-left: .4rem;
            }
        }

        .time {
            margin: 0 .4rem;
        }

        button {
            padding: .2rem;
            min-width: 0;
            min-height: 0;
        }
    }

    separator {
        margin: 0 .4rem;
        background-color: gtkalpha($fg-color, .1);
    }

    .content {
        margin: 1rem;
        margin-top: .5rem;

        .summary {
            font-size: 1.2em;
            color: $fg-color;
        }

        .body {
            color: gtkalpha($fg-color, 0.8);
        }

        .image {
            border: 1px solid gtkalpha($fg-color, .02);
            margin-right: .5rem;
            border-radius: 9px;
            min-width: 100px;
            min-height: 100px;
            background-size: cover;
            background-position: center;
        }
    }

    .actions {
        margin: 1rem;
        margin-top: 0;

        button {
            margin: 0 .3rem;

            &:first-child {
                margin-left: 0;
            }

            &:last-child {
                margin-right: 0;
            }
        }
    }
}