@import url('https://fonts.googleapis.com/css?family=Roboto');
@import url('indabom-colors.css');


main {
    min-height: 100vh;
}

p, li {
    font-size: 1.1rem; /* Slightly larger to compensate for thin weight */
    font-weight: 300;
}

/* We use significant size differences to replace the lack of bold weights */
h1 {
    font-size: 2.5rem;
    font-weight: 300;
    line-height: 1.1;
}

h2 {
    font-size: 2.0rem;
    font-weight: 300;
}

h3 {
    font-size: 1.7rem;
    font-weight: 300;
}

h4 {
    font-size: 1.4rem;
    font-weight: 300;
}

h5 {
    font-size: 1.1rem;
    font-weight: 400;
}

/* H5 kept at 400 so it doesn't vanish */

/* Desktop Scaling: To keep the "Premium" light look, we go big on large screens */
@media only screen and (min-width: 992px) {
    h1 {
        font-size: 3.8rem;
        letter-spacing: -1px;
    }

    h2 {
        font-size: 3.0rem;
        letter-spacing: -0.5px;
    }

    h3 {
        font-size: 2.0rem;
    }
}

.btn {
    border-radius: 20px;
}

.brand-logo {
    padding-left: 15px !important;
}

.tabs .tab a:focus, .tabs .tab a:focus.active {
    background-color: transparent;
}

.page-footer {
    margin-top: 50px;
}

.promo-caption {
    font-size: 1.7rem;
    font-weight: 500;
    margin-top: 5px;
    margin-bottom: 0;
}

input[type=text]:focus:not([readonly]) {
    box-shadow: 0 0px 0 0;
}

/* Cards */
.card {
    border-radius: 12px;
}

.card-panel {
    border-radius: 12px;
}

.card-panel .white {
    background-color: transparent !important;
}

.feature-card {
    transition: all 0.2s ease;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.feature-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 17px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

.highlighted-card {
    border: 3px solid #66BB6A;
    box-shadow: 0 6px 15px rgba(102, 187, 106, 0.6) !important;
}

.row-equal-height-cards {
    display: flex;
    flex-wrap: wrap;
}

.row-equal-height-cards > .col {
    display: flex; /* Make the column flexible */
}

.row-equal-height-cards .card-panel {
    flex-grow: 1; /* Tell the card to fill all available space */
}

.row-equal-height-cards .card {
    flex-grow: 1; /* Tell the card to fill all available space */
}

/* Large padding inside focused card content (e.g., forms) */
.card-pad-lg {
    padding: 30px;
}

/* Style for the footer area inside a card (e.g., "Already have an account?" link) */
.card-footer-separator {
    margin-top: 20px;
    padding-top: 15px;
    border-top: 1px solid #eee;
}

/* Screen size media queries */
@media only screen and (min-width: 600px) {
    .inline-flex-medium {
        display: inline-flex;
    }
}

/* Override materialize */
input.invalid:not([type]), input.invalid:not([type]):focus, input.invalid[type=text]:not(.browser-default), input.invalid[type=text]:not(.browser-default):focus, input.invalid[type=password]:not(.browser-default), input.invalid[type=password]:not(.browser-default):focus, input.invalid[type=email]:not(.browser-default), input.invalid[type=email]:not(.browser-default):focus, input.invalid[type=url]:not(.browser-default), input.invalid[type=url]:not(.browser-default):focus, input.invalid[type=time]:not(.browser-default), input.invalid[type=time]:not(.browser-default):focus, input.invalid[type=date]:not(.browser-default), input.invalid[type=date]:not(.browser-default):focus, input.invalid[type=datetime]:not(.browser-default), input.invalid[type=datetime]:not(.browser-default):focus, input.invalid[type=datetime-local]:not(.browser-default), input.invalid[type=datetime-local]:not(.browser-default):focus, input.invalid[type=tel]:not(.browser-default), input.invalid[type=tel]:not(.browser-default):focus, input.invalid[type=number]:not(.browser-default), input.invalid[type=number]:not(.browser-default):focus, input.invalid[type=search]:not(.browser-default), input.invalid[type=search]:not(.browser-default):focus, textarea.materialize-textarea.invalid, textarea.materialize-textarea.invalid:focus, .select-wrapper.invalid > input.select-dropdown, .select-wrapper.invalid > input.select-dropdown:focus {
    border-bottom: 1px solid #a5d6a7;
    -webkit-box-shadow: none;
    box-shadow: none;
}

#toast-container .toast {
    cursor: pointer;
}

#toast-container .toast::after {
    font-family: 'Material Icons';
    content: "close";
    -webkit-font-feature-settings: 'liga';
    /*color: #dd2c00;*/
    color: white;
    font-size: 1.5rem;
    font-weight: 300;
    float: right;
    padding-left: 3rem;
}

/* Printer friendly */
.printer-show {
    display: none;
}

@media print {
    .printer-show {
        display: block;
    }
}

/* 4. Feature List Styling (Custom list inside a card) */
/* Standardizes the look of custom lists used in feature, benefit, or pricing blocks. */
.feature-list {
    flex-grow: 1; /* Key for pushing card-action to the bottom on feature cards */
    padding: 0;
    margin: 0;
    border: none;
}

.feature-list li {
    padding: 10px 0;
    border-bottom: 1px solid #eee;
}

.feature-list li.collection-item {
    /* Override Materialize default horizontal padding for centering */
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* 5. Centering Content in List Items */
/* General utility to center text/icons within a flex container. */
.feature-item-content {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* --- Vertical Spacing Utilities --- */

/* Standard section padding for page wrapper (e.g., around the main container) */
.page-v-pad-lg {
    padding-top: 50px;
    padding-bottom: 20px;
}

/* Margin Top Utilities */
.mt-0 {
    margin-top: 0;
}

.mt-sm { /* Small margin top (e.g., between logo and heading) */
    margin-top: 15px;
}

.mt-md { /* Medium margin top (e.g., after the main heading block) */
    margin-top: 25px;
}

.mt-lg { /* Large margin top (e.g., starting a major new row/component block) */
    margin-top: 40px;
}

.mt-xl { /* Extra-large margin top (e.g., before the main CTA button) */
    margin-top: 30px;
}

/* Margin Bottom Utilities */
.mb-0 { /* Remove default Materialize bottom margin on rows */
    margin-bottom: 0;
}

.mb-sm {
    margin-bottom: 15px; /* Used below the logo */
}

/* --- Component Specific Styles --- */

/* Consistent style for separators directly under main headings */
.header-divider {
    max-width: 300px;
}

/* Responsive CTA Button Sizing (used for primary sign-up/login buttons) */
.btn-cta-responsive {
    width: 100%;
    max-width: 300px;
}

/* --- Forms --- */
form p {
    font-size: .8rem;
}

form li {
    font-size: .8rem;
}

/* --- Settings & Admin Layout Refinements (flat, Material-inspired) --- */
/* These rules lightly standardize the look of sectioned settings pages
   (e.g., Settings tabs) without impacting card-based marketing pages. */

/* Section spacing */
.container-app .section {
    padding-top: 16px;
    padding-bottom: 16px;
}

/* Consistent section headers with optional leading/trailing icons */
.container-app .section-title {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 8px 0; /* no extra space above headings inside sections */
    letter-spacing: 0.2px;
}

.container-app .section-title .material-icons {
    line-height: 1;
}

/* Trailing service logos (e.g., Google Drive) line up nicely with text */
.container-app .section-title img {
    height: 1.1rem;
    margin-left: 6px;
    vertical-align: middle;
}

/* When a service logo/image is used as a leading icon, adjust spacing */
.container-app .section-title img:first-child {
    margin-left: 0;
    margin-right: 6px;
}

/* Dividers provide comfortable breathing room between sections */
.container-app .divider {
    margin: 16px 0;
}

/* Paragraph sizing inside settings sections (denser than marketing pages) */
.container-app .section p {
    margin: 0 0 12px 0;
}

/* Tabs sit a bit away from content below (e.g., in Settings) */
.container-app .tabs {
    margin-bottom: 12px;
}

/* Flat collections (used for quick key-value lists) */
.container-app .collection.z-depth-0 {
    border: none;
}

.container-app .collection.z-depth-0 .collection-item {
    border: none;
    padding-left: 0; /* align with surrounding text blocks */
}

/* Button group spacing in right-aligned action rows */
.container-app .right-align .btn,
.container-app .right-align .btn-flat {
    margin-left: 4px;
}