@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');

@layer reset, base, layout, components, utilities;

@layer reset {

    *,
    *::before,
    *::after {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
    }

    html,
    body {
        height: 100%;
    }

    a {
        color: inherit;
        text-decoration: none;
    }

    button {
        cursor: pointer;
        border: none;
        background: none;
        font: inherit;
    }

    input,
    select,
    textarea {
        font: inherit;
        border: none;
        outline: none;
        background: none;
    }

    table {
        border-collapse: collapse;
        width: 100%;
    }
}

@layer base {
    :root {
        --black: #000000;
        --white: #FFFFFF;
        --mccann-red: #DA291C;
        --mccann-yellow: #FFC72C;
        --mccann-yellow-deep: #997000;
        --mccann-yellow-link: #FFC831;
        --mccann-tar: #191919;
        --border-primary: #C5C5C5;
        --detail-gray: #F3F3F3;
        --gray: #868686;

        --font-body: 'Inter', sans-serif;
        --font-header: 'Gill Sans', 'Gill Sans MT', Calibri, sans-serif;

        --text-xs: 11px;
        --text-sm: 13px;
        --text-base: 14px;
        --text-md: 15px;
        --text-lg: 18px;
        --text-xl: 22px;
        --text-2xl: 24px;
        --text-3xl: 28px;

        --radius: 4px;
        --max-width: 900px;
        --mobile-max: 430px;
    }

    body {
        font-family: var(--font-body);
        font-size: var(--text-md);
        color: var(--black);
        background: var(--white);
        -webkit-font-smoothing: antialiased;
    }
}

@layer layout {
    .page {
        min-height: 100vh;
        display: flex;
        flex-direction: column;
    }

    .content {
        flex: 1;
        padding: 24px 20px;
        max-width: var(--max-width);
        width: 100%;
        margin: 0 auto;
    }

    .content--centered {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        text-align: center;
        gap: 16px;
    }

    .navbar {
        background: var(--mccann-tar);
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 12px 20px;
        position: sticky;
        top: 0;
        z-index: 100;
    }

    .page-footer {
        padding: 12px 20px;
        background: var(--mccann-tar);
        color: var(--gray);
        font-size: var(--text-sm);
    }

    .page-header {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        margin-bottom: 12px;
    }

    .page-header-left {
        display: flex;
        align-items: center;
        gap: 12px;
    }

    .back-link {
        font-size: var(--text-lg);
        color: var(--black);
        line-height: 1;
    }

    .back-link:hover {
        color: var(--gray);
    }

    .divider {
        border: none;
        border-top: 1px solid var(--border-primary);
        margin-bottom: 24px;
    }

    .card-divider {
        border: none;
        border-top: 1px solid var(--border-primary);
        margin: 8px 0;
    }

    .section-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: 12px;
    }

    .group-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: 8px;
    }

    .form-actions {
        margin-top: 24px;
    }
}

@layer components {
    .navbar-title {
        font-family: var(--font-header);
        font-size: var(--text-base);
        color: var(--white);
        letter-spacing: 0.01em;
    }

    .navbar-logo {
        height: 28px;
        width: auto;
    }

    .page-title {
        font-size: var(--text-3xl);
        font-weight: 700;
        line-height: 1.1;
        letter-spacing: -0.02em;
    }

    .user-info {
        text-align: right;
        display: flex;
        flex-direction: column;
        gap: 2px;
    }

    .user-name {
        font-size: var(--text-md);
        font-weight: 600;
    }

    .user-role {
        font-size: var(--text-sm);
        color: var(--gray);
    }

    .group-label {
        font-size: var(--text-base);
        font-weight: 500;
        color: var(--gray);
        margin-bottom: 12px;
    }

    .section-title {
        font-size: var(--text-lg);
        font-weight: 600;
        margin-bottom: 12px;
    }

    .detail-section {
        margin-bottom: 28px;
    }

    .detail-row {
        display: flex;
        align-items: baseline;
        gap: 16px;
        padding: 8px 0;
        border-bottom: 1px solid var(--detail-gray);
    }

    .detail-row--total {
        border-bottom: none;
        padding-top: 12px;
        font-weight: 600;
    }

    .detail-label {
        font-size: var(--text-base);
        color: var(--gray);
        min-width: 90px;
    }

    .detail-value {
        font-size: var(--text-md);
        font-weight: 500;
    }

    .text-secondary {
        color: var(--gray);
        font-size: var(--text-md);
    }

    .job-card {
        padding: 12px 0;
        border-bottom: 1px solid var(--border-primary);
    }

    .job-card-main {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        margin-bottom: 4px;
    }

    .job-card-info {
        display: flex;
        flex-direction: column;
        gap: 2px;
    }

    .job-name {
        font-size: var(--text-lg);
        font-weight: 600;
    }

    .job-ref {
        font-size: var(--text-sm);
        color: var(--gray);
    }

    .job-card-meta {
        display: flex;
        flex-direction: column;
        align-items: flex-end;
        gap: 4px;
    }

    .job-site {
        font-size: var(--text-sm);
        color: var(--gray);
    }

    .job-card-actions {
        display: flex;
        gap: 16px;
        justify-content: flex-end;
        padding-top: 6px;
    }

    .job-group {
        margin-bottom: 32px;
    }

    .badge {
        display: inline-block;
        font-size: var(--text-xs);
        font-weight: 600;
        letter-spacing: 0.05em;
        padding: 2px 8px;
        border-radius: var(--radius);
        background: var(--detail-gray);
        color: var(--black);
    }

    .badge--active {
        background: var(--detail-gray);
        color: var(--black);
    }

    .badge--complete {
        background: var(--detail-gray);
        color: var(--gray);
    }

    .badge--submitted {
        background: var(--detail-gray);
        color: var(--gray);
    }

    .badge--approved {
        background: var(--black);
        color: var(--white);
    }

    .data-table {
        width: 100%;
        font-size: var(--text-base);
    }

    .data-table thead tr {
        background: var(--detail-gray);
    }

    .data-table th {
        padding: 10px 12px;
        text-align: left;
        font-weight: 500;
        font-size: var(--text-sm);
        white-space: nowrap;
    }

    .data-table td {
        padding: 10px 12px;
        border-bottom: 1px solid var(--detail-gray);
    }

    .empty-state {
        color: var(--gray);
        font-size: var(--text-base);
        text-align: center;
        padding: 24px 12px;
    }

    .resource-row {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 10px 0;
        margin: 10px 0;
        border-bottom: 1px solid var(--detail-gray);
    }

    .resource-name {
        flex: 1;
        font-size: var(--text-base);
        font-weight: 500;
    }

    .resource-qty,
    .resource-duration,
    .resource-arrival {
        font-size: var(--text-sm);
        color: var(--gray);
    }

    .resource-cost {
        font-size: var(--text-base);
        font-weight: 600;
        min-width: 80px;
        text-align: right;
    }

    .form {
        display: flex;
        flex-direction: column;
        gap: 16px;
        max-width: 560px;
    }

    .field {
        display: flex;
        flex-direction: column;
        gap: 0;
    }

    .button-field {
        display: flex;
        flex-direction: row;
        gap: 12px;
    }

    .field-error {
        display: block;
        background: var(--mccann-red);
        color: var(--white);
        font-size: var(--text-sm);
        padding: 6px 12px;
    }

    .input {
        width: 100%;
        padding: 14px 16px;
        border: 1px solid var(--border-primary);
        border-radius: var(--radius);
        font-size: var(--text-md);
        color: var(--black);
        background: var(--white);
        transition: border-color 0.15s;
    }

    .input::placeholder {
        color: var(--gray);
    }

    .input:focus {
        border-color: var(--black);
    }

    .input--error {
        border-color: var(--mccann-red);
        color: var(--mccann-red);
    }

    .input--error::placeholder {
        color: var(--mccann-red);
    }

    .select {
        appearance: none;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23868686' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 16px center;
        padding-right: 40px;
    }

    .textarea {
        resize: vertical;
        min-height: 100px;
    }

    .input-with-action {
        position: relative;
        display: flex;
        align-items: center;
    }

    .input-with-action .input {
        padding-right: 60px;
    }

    .show-password {
        position: absolute;
        right: 16px;
        font-size: var(--text-base);
        color: var(--mccann-yellow-link);
        font-weight: 500;
        background: none;
        border: none;
        cursor: pointer;
    }

    .btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 14px 24px;
        border-radius: var(--radius);
        font-size: var(--text-md);
        font-weight: 500;
        transition: opacity 0.15s;
        cursor: pointer;
        border: none;
    }

    .btn:hover {
        opacity: 0.85;
    }

    .btn--primary {
        background: var(--black);
        color: var(--white);
    }

    .btn--secondary {
        background: var(--detail-gray);
        color: var(--black);
    }

    .btn--danger {
        background: var(--mccann-red);
        color: var(--white);
    }

    .btn--full {
        width: 100%;
    }

    .btn--sm {
        padding: 8px 16px;
        font-size: var(--text-sm);
    }

    .action-link-more svg path {
        color: var(--mccann-yellow-link);

        &:hover {
            color: var(--mccann-yellow-deep);
        }
    }



    .action-link {
        font-size: var(--text-base);
        font-weight: 500;
        color: var(--mccann-yellow-link);
    }

    .action-link:hover {
        color: var(--mccann-yellow-deep);
    }

    .action-link--danger {
        color: var(--mccann-red);
    }

    .brand {
        color: var(--mccann-red);
        font-weight: 700;
    }

    .page-login {
        min-height: 100vh;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        padding: 48px 32px 32px;
        max-width: var(--mobile-max);
        margin: 0 auto;
    }

    .login-header {
        margin-bottom: 32px;
    }

    .login-header hr {
        border: none;
        border-top: 1px solid var(--border-primary);
        margin-bottom: 12px;
    }

    .login-header h1 {
        font-size: var(--text-xl);
        font-weight: 400;
        view-transition-name: login-title;
    }

    .login-form {
        display: flex;
        flex-direction: column;
        gap: 16px;

        form {
            display: flex;
            flex-direction: column;
            gap: 12px;
        }
    }

    .login-footer {
        padding-top: 32px;
    }

    .login-footer .logo {
        height: 32px;
        width: auto;
    }

    .status-actions {
        display: flex;
        gap: 12px;
        margin-top: 16px;
    }

    @keyframes fade-in {
        from {
            opacity: 0;
        }

        to {
            opacity: 1;
        }
    }
}

@layer utilities {
    .sr-only {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border-width: 0;
    }

    @media (max-width: 480px) {
        .content {
            padding: 20px 16px;
        }

        .page-title {
            font-size: var(--text-2xl);
        }

        .data-table {
            font-size: var(--text-sm);
        }

        .data-table th,
        .data-table td {
            padding: 8px;
        }
    }

    @media (min-width: 768px) {
        .form {
            max-width: 480px;
        }

        .page-login {
            max-width: 560px;
        }
    }
}