/* ==========================================
   NEWSTRP APP.CSS
   Global Foundation
========================================== */

@import url('variables.css');

/* ==========================================
   RESET
========================================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    background:var(--bg);
    color:var(--text);
    font-family:var(--font-family);
    font-size:var(--font-md);
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
}

img{
    max-width:100%;
    display:block;
}

a{
    color:inherit;
    text-decoration:none;
}

ul,
ol{
    list-style:none;
}

button{
    border:none;
    outline:none;
    cursor:pointer;
    font-family:inherit;
}

input,
textarea,
select{
    font-family:inherit;
    outline:none;
}

textarea{
    resize:vertical;
}

/* ==========================================
   SCROLLBAR
========================================== */

::-webkit-scrollbar{
    width:8px;
    height:8px;
}

::-webkit-scrollbar-track{
    background:transparent;
}

::-webkit-scrollbar-thumb{
    background:#d1d5db;
    border-radius:999px;
}

::-webkit-scrollbar-thumb:hover{
    background:#9ca3af;
}

/* ==========================================
   TYPOGRAPHY
========================================== */

h1{
    font-size:var(--font-3xl);
    font-weight:var(--fw-extra);
    line-height:1.2;
}

h2{
    font-size:var(--font-2xl);
    font-weight:var(--fw-bold);
}

h3{
    font-size:var(--font-xl);
    font-weight:var(--fw-bold);
}

h4{
    font-size:var(--font-lg);
    font-weight:var(--fw-semibold);
}

h5{
    font-size:var(--font-md);
    font-weight:var(--fw-semibold);
}

h6{
    font-size:var(--font-sm);
    font-weight:var(--fw-semibold);
}

.text-muted{
    color:var(--text-muted);
}

.text-light{
    color:var(--text-light);
}

.text-primary{
    color:var(--primary);
}

.text-secondary{
    color:var(--secondary);
}

.text-center{
    text-align:center;
}

.text-right{
    text-align:right;
}

.fw-bold{
    font-weight:700;
}

.fw-semibold{
    font-weight:600;
}

/* ==========================================
   CONTAINER
========================================== */

.container{
    width:100%;
    max-width:var(--container);
    margin:auto;
    padding-left:20px;
    padding-right:20px;
}

/* ==========================================
   CARDS
========================================== */

.card{
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-sm);
}

.card-body{
    padding:20px;
}

.card-header{
    padding:20px;
    border-bottom:1px solid var(--border);
}

.card-footer{
    padding:20px;
    border-top:1px solid var(--border);
}

/* ==========================================
   BUTTONS
========================================== */

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:12px 20px;
    border-radius:12px;
    font-size:14px;
    font-weight:600;
    transition:var(--transition);
}

.btn:hover{
    transform:translateY(-1px);
}

.btn-primary{
    background:var(--primary);
    color:#fff;
}

.btn-primary:hover{
    background:var(--primary-hover);
}

.btn-secondary{
    background:var(--secondary);
    color:#fff;
}

.btn-secondary:hover{
    background:var(--secondary-hover);
}

.btn-outline{
    background:#fff;
    border:1px solid var(--border);
}

.btn-outline:hover{
    background:#f9fafb;
}

.btn-full{
    width:100%;
}

/* ==========================================
   FORM
========================================== */

.form-group{
    margin-bottom:18px;
}

.form-label{
    display:block;
    margin-bottom:8px;
    font-weight:600;
    font-size:14px;
}

.form-control{
    width:100%;
    height:50px;
    border:1px solid var(--border);
    border-radius:12px;
    padding:0 16px;
    background:#fff;
    font-size:15px;
    transition:var(--transition);
}

.form-control:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(0,121,255,.12);
}

textarea.form-control{
    min-height:140px;
    padding:16px;
}

/* ==========================================
   AVATAR
========================================== */

.avatar{
    border-radius:50%;
    object-fit:cover;
}

.avatar-sm{
    width:36px;
    height:36px;
}

.avatar-md{
    width:48px;
    height:48px;
}

.avatar-lg{
    width:64px;
    height:64px;
}

.avatar-xl{
    width:96px;
    height:96px;
}

/* ==========================================
   BADGES
========================================== */

.badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:6px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:600;
}

.badge-primary{
    background:var(--primary-light);
    color:var(--primary);
}

.badge-secondary{
    background:var(--secondary-light);
    color:var(--secondary);
}

/* ==========================================
   FLEX
========================================== */

.d-flex{
    display:flex;
}

.align-center{
    align-items:center;
}

.justify-between{
    justify-content:space-between;
}

.justify-center{
    justify-content:center;
}

.gap-10{
    gap:10px;
}

.gap-15{
    gap:15px;
}

.gap-20{
    gap:20px;
}

/* ==========================================
   SPACING
========================================== */

.mt-10{margin-top:10px;}
.mt-20{margin-top:20px;}
.mt-30{margin-top:30px;}

.mb-10{margin-bottom:10px;}
.mb-20{margin-bottom:20px;}
.mb-30{margin-bottom:30px;}

.p-20{padding:20px;}
.p-30{padding:30px;}

/* ==========================================
   LOADER
========================================== */

.loader{
    width:40px;
    height:40px;
    border:4px solid #e5e7eb;
    border-top-color:var(--primary);
    border-radius:50%;
    animation:spin .8s linear infinite;
}

@keyframes spin{

    from{
        transform:rotate(0deg);
    }

    to{
        transform:rotate(360deg);
    }

}

/* ==========================================
   SKELETON
========================================== */

.skeleton{
    background:
    linear-gradient(
        90deg,
        #f3f4f6 25%,
        #e5e7eb 50%,
        #f3f4f6 75%
    );

    background-size:200% 100%;

    animation:skeleton 1.2s infinite;
}

@keyframes skeleton{

    0%{
        background-position:200% 0;
    }

    100%{
        background-position:-200% 0;
    }

}

/* ==========================================
   HIDE
========================================== */

.hidden{
    display:none !important;
}

/* ==========================================
   MOBILE
========================================== */

@media(max-width:768px){

    body{
        padding-bottom:80px;
    }

    h1{
        font-size:28px;
    }

    h2{
        font-size:22px;
    }

    .container{
        padding-left:14px;
        padding-right:14px;
    }

}