/*=== global ===*/

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    scroll-behavior: smooth;
    line-height: normal;
    font-family: 'Raleway', sans-serif;
    font-size: 8px;
}

html,
body {
    scrollbar-gutter: stable;
}

:root {
    --primary-color: #9f0908;
    --secondary-color: #0a141e;
    --accent-color: #675e54;
    --background-color: #fbfbfb;
    --text-color: #333;
    --desktop-padding: clamp(6rem, 5vh, 8rem) clamp(3rem, -27.857rem + 32.143vw, 30rem) 0;
}

body {
    font-size: clamp(2rem, 1vw, 3rem);
    background-color: var(--background-color);
    color: var(--text-color);
}

h1 {
    font-size: clamp(9rem, 9vw, 12rem);
    font-weight: bold;
    text-transform: uppercase;
    color: var(--background-color);
}

h2 {
    font-size: clamp(8rem, 6vw, 10rem);
    text-transform: uppercase;
    text-align: center;
    font-weight: bold;
    color: var(--primary-color);
}

h3 {
    font-family: economica, sans-serif;
    font-size: clamp(5rem, 4vw, 7rem);
    font-weight: bold;
    color: var(--text-color);
}

h4 {
    font-size: clamp(20px, 2vw, 3rem);
    font-weight: 500;
    text-transform: uppercase;
    color: var(--background-color);
}

h5 {
    font-size: clamp(2rem, 3vw, 4rem);
    font-weight: 700;
    color: var(--text-color);
}

p {
    font-size: clamp(20px, 2vw, 3rem);
    color: var(--text-color);
}

a {
    text-decoration: none;
    color: var(--text-color);
    font-size: clamp(20px, 2vw, 3rem);
}

table {
    border-collapse: collapse;
}

th {
    font-family: economica, sans-serif;
    font-size: clamp(4rem, -3.385rem + 5.769vw, 7rem);
    text-align: left;
    font-weight: bold;
    color: var(--text-color);
    padding-bottom: 2rem;
}

td {
    padding-bottom: 1rem;
    text-align: left;
    font-weight: bold;
    text-transform: uppercase;
    font-size: clamp(3rem, 0.538rem + 1.923vw, 4rem);
    color: var(--accent-color);
}

td:first-child,
th:first-child {
    width: clamp(33rem, 3.462rem + 23.077vw, 45rem);
}

ul li {
    list-style: none;
    ;
}

/*=== global END ===*/

/*=== header ===*/

header {
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-image: url(../img/1_hero/JPG/hero_bg.jpg);
    background-size: cover;
    background-position: bottom;
    padding: 0 2rem;
}

.header_title {
    position: relative;
    top: -22vh;
    text-align: center;
}

nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    width: 100%;
    height: 14rem;
    padding: var(--desktop-padding);
}

.logo {
    height: 8rem;
}

.header_nav {
    display: flex;
    gap: 5rem;
    align-items: center;
    list-style: none;
}

.header_nav a {
    color: var(--background-color);
    font-weight: 500;
    text-transform: uppercase;
    transition: color 0.3s ease-in-out;
}

.header_nav a:hover {
    color: var(--accent-color);
}

.telephone_btn {
    display: flex;
    align-items: center;
    gap: 1rem;
    background-color: var(--primary-color);
    border: 2px solid var(--background-color);
    border-radius: 1.5rem;
    padding: 1rem 2rem;
}

li.telephone_btn:hover {
    background-color: #cb1817;
    color: var(--background-color);
}

li.telephone_btn a:hover {
    color: var(--background-color);
}

/*=== header END ===*/

/*=== main ===*/

/*=== section ===*/

section {
    padding: clamp(12rem, 9vw, 15rem) 0;
}

.section_content {
    padding: var(--desktop-padding);
}

.order_instr_pictogram {
    display: flex;
    justify-content: space-between;
}

.instruction {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(1rem, 1.125vw, 2rem);
}

.instruction_img {
    width: clamp(14rem, 15vw, 16rem);
}

.instruction_text {
    font-family: economica, sans-serif;
    font-size: clamp(4rem, 4vw, 7rem);
    font-weight: bold;
    color: var(--text-color);
    text-align: center;
    width: 10ch;
}

#menu {
    background-image: url(../img/3_section_our_menu/JPG/section_our_menu_bg.jpg);
    background-size: cover;
    background-position: center;
}

.ramen {
    display: flex;
    flex-direction: column;
    gap: clamp(5rem, 8vw, 7rem);
}

.ramen_type {
    display: flex;
    align-items: center;
    gap: 10rem;
}

.ramen_type:nth-child(even) {
    flex-direction: row-reverse;
}

img.ramen_img {
    max-width: clamp(40rem, 36rem + 6.4vw, 44rem);
    width: 100%;
    height: auto;
    object-fit: cover;
}

.adresse {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-top: 1rem;
}

.map_frame {
    width: 100%;
    height: 80vh;
    margin: clamp(6rem, 5vw, 8rem) 0 clamp(0rem, 2vw, 2rem);
}

section:last-child {
    padding-bottom: 0;
}

/*=== section END ===*/

/*=== main END ===*/

/*=== footer ===*/

footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--secondary-color);
    color: var(--background-color);
    padding: 40px clamp(3rem, 17vw, 30rem) 38px
}

.mobile_footer_logo {
    display: none;
}

.footer_logo img {
    height: 44px;
}

.social_icons {
    display: flex;
    gap: 2rem;
}

social_icon_link {
    height: 44px;
}

.social_icon {
    height: clamp(5rem, 4vw, 44px);
    width: clamp(5rem, 4vw, 44px);
    transition: transform 0.3s ease-in-out;
}

.social_icon:hover {
    transform: scale(1.2);
}

/*=== footer END ===*/